| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 | package analyticimport (	"github.com/shirou/gopsutil/v4/net"	"github.com/uozi-tech/cosy/logger"	"time")type Usage[T uint64 | float64] struct {	Time  time.Time `json:"x"`	Usage T         `json:"y"`}var (	CpuUserRecord   []Usage[float64]	CpuTotalRecord  []Usage[float64]	NetRecvRecord   []Usage[uint64]	NetSentRecord   []Usage[uint64]	DiskWriteRecord []Usage[uint64]	DiskReadRecord  []Usage[uint64]	LastDiskWrites  uint64	LastDiskReads   uint64	LastNetSent     uint64	LastNetRecv     uint64)func init() {	network, err := net.IOCounters(false)	if err != nil {		logger.Error(err)	}	if len(network) > 0 {		LastNetRecv = network[0].BytesRecv		LastNetSent = network[0].BytesSent	}	LastDiskReads, LastDiskWrites = getTotalDiskIO()	now := time.Now()	// init record slices	for i := 100; i > 0; i-- {		uf := Usage[float64]{Time: now.Add(time.Duration(-i) * time.Second), Usage: 0}		CpuUserRecord = append(CpuUserRecord, uf)		CpuTotalRecord = append(CpuTotalRecord, uf)		u := Usage[uint64]{Time: now.Add(time.Duration(-i) * time.Second), Usage: 0}		NetRecvRecord = append(NetRecvRecord, u)		NetSentRecord = append(NetSentRecord, u)		DiskWriteRecord = append(DiskWriteRecord, u)		DiskReadRecord = append(DiskReadRecord, u)	}}func RecordServerAnalytic() {	logger.Info("RecordServerAnalytic Started")	for {		now := time.Now()		recordCpu(now) // this func will spend more than 1 second.		recordNetwork(now)		recordDiskIO(now)	}}
 |