forked from elastic/beats
-
Notifications
You must be signed in to change notification settings - Fork 0
/
helper.go
43 lines (37 loc) · 1.26 KB
/
helper.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
package memory
import (
"github.com/elastic/beats/libbeat/common"
"github.com/elastic/beats/metricbeat/module/docker"
)
type MemoryData struct {
Time common.Time
Container *docker.Container
Failcnt uint64
Limit uint64
MaxUsage uint64
TotalRss uint64
TotalRssP float64
Usage uint64
UsageP float64
}
type MemoryService struct{}
func (s *MemoryService) getMemoryStatsList(rawStats []docker.Stat) []MemoryData {
formattedStats := []MemoryData{}
for _, myRawStats := range rawStats {
formattedStats = append(formattedStats, s.GetMemoryStats(myRawStats))
}
return formattedStats
}
func (s *MemoryService) GetMemoryStats(myRawStat docker.Stat) MemoryData {
return MemoryData{
Time: common.Time(myRawStat.Stats.Read),
Container: docker.NewContainer(&myRawStat.Container),
Failcnt: myRawStat.Stats.MemoryStats.Failcnt,
Limit: myRawStat.Stats.MemoryStats.Limit,
MaxUsage: myRawStat.Stats.MemoryStats.MaxUsage,
TotalRss: myRawStat.Stats.MemoryStats.Stats.TotalRss,
TotalRssP: float64(myRawStat.Stats.MemoryStats.Stats.TotalRss) / float64(myRawStat.Stats.MemoryStats.Limit),
Usage: myRawStat.Stats.MemoryStats.Usage,
UsageP: float64(myRawStat.Stats.MemoryStats.Usage) / float64(myRawStat.Stats.MemoryStats.Limit),
}
}