You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
33 lines
670 B
33 lines
670 B
2 years ago
|
package statistics
|
||
|
|
||
|
import (
|
||
|
"Open_IM/pkg/common/log"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
type Statistics struct {
|
||
|
Count *uint64
|
||
|
ModuleName string
|
||
|
PrintArgs string
|
||
|
SleepTime int
|
||
|
}
|
||
|
|
||
|
func (s *Statistics) output() {
|
||
|
t := time.NewTicker(time.Duration(s.SleepTime) * time.Second)
|
||
|
defer t.Stop()
|
||
|
var sum uint64
|
||
|
for {
|
||
|
sum = *s.Count
|
||
|
select {
|
||
|
case <-t.C:
|
||
|
}
|
||
|
log.NewWarn("", " system stat ", s.ModuleName, s.PrintArgs, *s.Count-sum, "total:", *s.Count)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func NewStatistics(count *uint64, moduleName, printArgs string, sleepTime int) *Statistics {
|
||
|
p := &Statistics{Count: count, ModuleName: moduleName, SleepTime: sleepTime, PrintArgs: printArgs}
|
||
|
go p.output()
|
||
|
return p
|
||
|
}
|