12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- package load
- import (
- "sync/atomic"
- "time"
- "git.i2edu.net/i2/go-zero/core/logx"
- "git.i2edu.net/i2/go-zero/core/stat"
- )
- type (
- // A SheddingStat is used to store the statistics for load shedding.
- SheddingStat struct {
- name string
- total int64
- pass int64
- drop int64
- }
- snapshot struct {
- Total int64
- Pass int64
- Drop int64
- }
- )
- // NewSheddingStat returns a SheddingStat.
- func NewSheddingStat(name string) *SheddingStat {
- st := &SheddingStat{
- name: name,
- }
- go st.run()
- return st
- }
- // IncrementTotal increments the total requests.
- func (s *SheddingStat) IncrementTotal() {
- atomic.AddInt64(&s.total, 1)
- }
- // IncrementPass increments the passed requests.
- func (s *SheddingStat) IncrementPass() {
- atomic.AddInt64(&s.pass, 1)
- }
- // IncrementDrop increments the dropped requests.
- func (s *SheddingStat) IncrementDrop() {
- atomic.AddInt64(&s.drop, 1)
- }
- func (s *SheddingStat) reset() snapshot {
- return snapshot{
- Total: atomic.SwapInt64(&s.total, 0),
- Pass: atomic.SwapInt64(&s.pass, 0),
- Drop: atomic.SwapInt64(&s.drop, 0),
- }
- }
- func (s *SheddingStat) run() {
- ticker := time.NewTicker(time.Minute)
- defer ticker.Stop()
- for range ticker.C {
- c := stat.CpuUsage()
- st := s.reset()
- if st.Drop == 0 {
- logx.Statf("(%s) shedding_stat [1m], cpu: %d, total: %d, pass: %d, drop: %d",
- s.name, c, st.Total, st.Pass, st.Drop)
- } else {
- logx.Statf("(%s) shedding_stat_drop [1m], cpu: %d, total: %d, pass: %d, drop: %d",
- s.name, c, st.Total, st.Pass, st.Drop)
- }
- }
- }
|