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.
|
|
|
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
|
|
|
|
}
|