Skip to content

Commit

Permalink
Merge branch 'main' into dependabot/go_modules/github.com/prometheus/…
Browse files Browse the repository at this point in the history
…client_model-0.5.0
  • Loading branch information
JasonYangShadow authored Nov 24, 2023
2 parents a824d51 + 2a78ecb commit 81d0a53
Show file tree
Hide file tree
Showing 7 changed files with 145 additions and 67 deletions.
4 changes: 4 additions & 0 deletions .golangci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,10 @@ linters:
- errcheck
- thelper
- usestdlibvars
- deadcode
- varcheck
- structcheck
- protogetter

linters-settings:
goheader:
Expand Down
16 changes: 8 additions & 8 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,13 @@ require (
github.com/go-kit/log v0.2.1
github.com/golang/protobuf v1.5.3
github.com/golang/snappy v0.0.4
github.com/opencontainers/runc v1.1.9
github.com/opencontainers/runc v1.1.10
github.com/prometheus/client_golang v1.17.0
github.com/prometheus/client_model v0.5.0
github.com/prometheus/common v0.44.0
github.com/prometheus/common v0.45.0
github.com/prometheus/exporter-toolkit v0.10.0
github.com/stretchr/testify v1.8.4
golang.org/x/sys v0.11.0
golang.org/x/sys v0.13.0
toolman.org/net/peercred v0.6.1
)

Expand All @@ -30,7 +30,7 @@ require (
github.com/jpillora/backoff v1.0.0 // indirect
github.com/julienschmidt/httprouter v1.3.0 // indirect
github.com/kr/text v0.2.0 // indirect
github.com/matttproud/golang_protobuf_extensions v1.0.4 // indirect
github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0 // indirect
github.com/moby/sys/mountinfo v0.5.0 // indirect
github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f // indirect
github.com/opencontainers/runtime-spec v1.0.3-0.20210326190908-1c3f411f0417 // indirect
Expand All @@ -39,11 +39,11 @@ require (
github.com/sirupsen/logrus v1.8.1 // indirect
github.com/stretchr/objx v0.5.0 // indirect
github.com/xhit/go-str2duration/v2 v2.1.0 // indirect
golang.org/x/crypto v0.8.0 // indirect
golang.org/x/net v0.10.0 // indirect
golang.org/x/oauth2 v0.8.0 // indirect
golang.org/x/crypto v0.14.0 // indirect
golang.org/x/net v0.17.0 // indirect
golang.org/x/oauth2 v0.12.0 // indirect
golang.org/x/sync v0.3.0 // indirect
golang.org/x/text v0.9.0 // indirect
golang.org/x/text v0.13.0 // indirect
google.golang.org/appengine v1.6.7 // indirect
google.golang.org/protobuf v1.31.0 // indirect
gopkg.in/yaml.v2 v2.4.0 // indirect
Expand Down
34 changes: 16 additions & 18 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ github.com/go-logfmt/logfmt v0.5.1/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KE
github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
github.com/godbus/dbus/v5 v5.0.6 h1:mkgN1ofwASrYnJ5W6U/BxG15eXXXjirgZc7CLqkcaro=
github.com/godbus/dbus/v5 v5.0.6/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg=
Expand All @@ -47,14 +46,14 @@ github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo=
github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4=
github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0 h1:jWpvCLoY8Z/e3VKvlsiIGKtc+UG6U5vzxaoagmhXfyg=
github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0/go.mod h1:QUyp042oQthUoa9bqDv0ER0wrtXnBruoNd7aNjkbP+k=
github.com/moby/sys/mountinfo v0.5.0 h1:2Ks8/r6lopsxWi9m58nlwjaeSzUX9iiL1vj5qB/9ObI=
github.com/moby/sys/mountinfo v0.5.0/go.mod h1:3bMD3Rg+zkqx8MRYPi7Pyb0Ie97QEBmdxbhnCLlSvSU=
github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f h1:KUppIJq7/+SVif2QVs3tOP0zanoHgBEVAwHxUSIzRqU=
github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
github.com/opencontainers/runc v1.1.9 h1:XR0VIHTGce5eWPkaPesqTBrhW2yAcaraWfsEalNwQLM=
github.com/opencontainers/runc v1.1.9/go.mod h1:CbUumNnWCuTGFukNXahoo/RFBZvDAgRh/smNYNOhA50=
github.com/opencontainers/runc v1.1.10 h1:EaL5WeO9lv9wmS6SASjszOeQdSctvpbu0DdBQBizE40=
github.com/opencontainers/runc v1.1.10/go.mod h1:+/R6+KmDlh+hOO8NkjmgkG9Qzvypzk0yXxAPYYR65+M=
github.com/opencontainers/runtime-spec v1.0.3-0.20210326190908-1c3f411f0417 h1:3snG66yBm59tKhhSPQrQ/0bCrv1LQbKt40LnUPiUxdc=
github.com/opencontainers/runtime-spec v1.0.3-0.20210326190908-1c3f411f0417/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
Expand All @@ -63,8 +62,8 @@ github.com/prometheus/client_golang v1.17.0 h1:rl2sfwZMtSthVU752MqfjQozy7blglC+1
github.com/prometheus/client_golang v1.17.0/go.mod h1:VeL+gMmOAxkS2IqfCq0ZmHSL+LjWfWDUmp1mBz9JgUY=
github.com/prometheus/client_model v0.5.0 h1:VQw1hfvPvk3Uv6Qf29VrPF32JB6rtbgI6cYPYQjL0Qw=
github.com/prometheus/client_model v0.5.0/go.mod h1:dTiFglRmd66nLR9Pv9f0mZi7B7fk5Pm3gvsjB5tr+kI=
github.com/prometheus/common v0.44.0 h1:+5BrQJwiBB9xsMygAB3TNvpQKOwlkc25LbISbrdOOfY=
github.com/prometheus/common v0.44.0/go.mod h1:ofAIvZbQ1e/nugmZGz4/qCb9Ap1VoSTIO7x0VV9VvuY=
github.com/prometheus/common v0.45.0 h1:2BGz0eBc2hdMDLnO/8n0jeB3oPrt2D08CekT0lneoxM=
github.com/prometheus/common v0.45.0/go.mod h1:YJmSTw9BoKxJplESWWxlbyttQR4uaEcGyv9MZjVOJsY=
github.com/prometheus/exporter-toolkit v0.10.0 h1:yOAzZTi4M22ZzVxD+fhy1URTuNRj/36uQJJ5S8IPza8=
github.com/prometheus/exporter-toolkit v0.10.0/go.mod h1:+sVFzuvV5JDyw+Ih6p3zFxZNVnKQa3x5qPmDSiPu4ZY=
github.com/prometheus/procfs v0.11.1 h1:xRC8Iq1yyca5ypa9n1EZnWZkt7dwcoRPQwX/5gwaUuI=
Expand All @@ -88,27 +87,26 @@ github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXl
github.com/xhit/go-str2duration/v2 v2.1.0 h1:lxklc02Drh6ynqX+DdPyp5pCKLUQpRT8bp8Ydu2Bstc=
github.com/xhit/go-str2duration/v2 v2.1.0/go.mod h1:ohY8p+0f07DiV6Em5LKB0s2YpLtXVyJfNt1+BlmyAsU=
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
golang.org/x/crypto v0.8.0 h1:pd9TJtTueMTVQXzk8E2XESSMQDj/U7OUu0PqJqPXQjQ=
golang.org/x/crypto v0.8.0/go.mod h1:mRqEX+O9/h5TFCrQhkgjo2yKi0yYA+9ecGkdQoHrywE=
golang.org/x/crypto v0.14.0 h1:wBqGXzWJW6m1XrIKlAH0Hs1JJ7+9KBwnIO8v66Q9cHc=
golang.org/x/crypto v0.14.0/go.mod h1:MVFd36DqK4CsrnJYDkBA3VC4m2GkXAM0PvzMCn4JQf4=
golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks=
golang.org/x/net v0.10.0 h1:X2//UzNDwYmtCLn7To6G58Wr6f5ahEAQgKNzv9Y951M=
golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg=
golang.org/x/oauth2 v0.8.0 h1:6dkIjl3j3LtZ/O3sTgZTMsLKSftL/B8Zgq4huOIIUu8=
golang.org/x/oauth2 v0.8.0/go.mod h1:yr7u4HXZRm1R1kBWqr/xKNqewf0plRYoB7sla+BCIXE=
golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/net v0.17.0 h1:pVaXccu2ozPjCXewfr1S7xza/zcXTity9cCdXQYSjIM=
golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE=
golang.org/x/oauth2 v0.12.0 h1:smVPGxink+n1ZI5pkQa8y6fZT0RW0MgCO5bFpepy4B4=
golang.org/x/oauth2 v0.12.0/go.mod h1:A74bZ3aGXgCY0qaIC9Ahg6Lglin4AMAco8cIv9baba4=
golang.org/x/sync v0.3.0 h1:ftCYgMx6zT/asHUrPw8BLLscYtGznsLAnjq5RH9P66E=
golang.org/x/sync v0.3.0/go.mod h1:FU7BRWz2tNW+3quACPkgCx/L+uEAv1htQ0V83Z9Rj+Y=
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210906170528-6f6e22806c34/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211025201205-69cdffdb9359/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.11.0 h1:eG7RXZHdqOJ1i+0lgLgCpSXAp6M3LYlAo6osgSi0xOM=
golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.13.0 h1:Af8nKPmuFypiUBjVoU9V20FiaFXOcuZI21p0ycVYYGE=
golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
golang.org/x/text v0.9.0 h1:2sjJmO8cDvYveuX97RDLsxlyUxLl+GHoLxBiRdHllBE=
golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8=
golang.org/x/text v0.13.0 h1:ablQoSUd0tRdKxZewP80B+BaqeKJuVhuRxj/dkrun3k=
golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE=
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
google.golang.org/appengine v1.6.7 h1:FZR1q0exgwxzPzp/aF+VccGrSfxfPpkBqjIIEq3ru6c=
Expand Down
7 changes: 4 additions & 3 deletions internal/cgroup/cgroup.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ func (c *CGroup) CreateStats() ([]parser.StatFunc, error) {
}

statManager := &parser.StatManager{Stats: stat}
statManager.WithCPU().WithMemory().WithMemorySwap().WithPid()
statManager.WithCPU().WithMemory().WithMemorySwap().WithPid().WithBlkIO()
return statManager.All(), nil
}

Expand All @@ -52,8 +52,9 @@ func (c *CGroup) Marshal(buffer *bytes.Buffer) (*bytes.Buffer, error) {

// write stats
for _, stat := range stats {
key, val := stat()
fmt.Fprintf(buffer, "%s %f\n", key, val)
for k, v := range stat() {
fmt.Fprintf(buffer, "%s %f\n", k, v)
}
}

return buffer, nil
Expand Down
65 changes: 47 additions & 18 deletions internal/cgroup/cgroup_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,61 +15,90 @@ type MockCgroupManager struct {
mock.Mock
}

func (m *MockCgroupManager) Apply(_ int) error {
return nil
func (m *MockCgroupManager) Apply(pid int) error {
args := m.Called(pid)
return args.Error(0)
}

func (m *MockCgroupManager) GetPids() ([]int, error) {
return []int{}, nil
args := m.Called()
return args.Get(0).([]int), args.Error(1)
}

func (m *MockCgroupManager) GetAllPids() ([]int, error) {
return []int{}, nil
args := m.Called()
return args.Get(0).([]int), args.Error(1)
}

func (m *MockCgroupManager) GetStats() (*cgroups.Stats, error) {
return cgroups.NewStats(), nil
args := m.Called()
return args.Get(0).(*cgroups.Stats), args.Error(1)
}

func (m *MockCgroupManager) Freeze(_ configs.FreezerState) error {
return nil
func (m *MockCgroupManager) Freeze(state configs.FreezerState) error {
args := m.Called(state)
return args.Error(0)
}

func (m *MockCgroupManager) Destroy() error {
return nil
args := m.Called()
return args.Error(0)
}

func (m *MockCgroupManager) Path(path string) string {
return path
args := m.Called(path)
return args.String(0)
}

func (m *MockCgroupManager) Set(_ *configs.Resources) error {
return nil
func (m *MockCgroupManager) Set(resource *configs.Resources) error {
args := m.Called(resource)
return args.Error(0)
}

func (m *MockCgroupManager) GetPaths() map[string]string {
return map[string]string{}
args := m.Called()
return args.Get(0).(map[string]string)
}

func (m *MockCgroupManager) GetCgroups() (*configs.Cgroup, error) {
return nil, nil
args := m.Called()
return args.Get(0).(*configs.Cgroup), args.Error(1)
}

func (m *MockCgroupManager) GetFreezerState() (configs.FreezerState, error) {
return "", nil
args := m.Called()
return args.Get(0).(configs.FreezerState), args.Error(1)
}

func (m *MockCgroupManager) Exists() bool {
return true
args := m.Called()
return args.Bool(0)
}

func (m *MockCgroupManager) OOMKillCount() (uint64, error) {
return 0, nil
args := m.Called()
return uint64(args.Int(0)), args.Error(1)
}

func TestCgroup(t *testing.T) {
mockManager := new(MockCgroupManager)
// set mock behaviors
mockManager.On("Apply", mock.Anything).Return(nil)
mockManager.On("GetPids").Return([]int{}, nil)
mockManager.On("GetAllPids").Return([]int{}, nil)
mockManager.On("GetStats").Return(cgroups.NewStats(), nil)
mockManager.On("Freeze", mock.Anything).Return(nil)
mockManager.On("Destroy").Return(nil)
mockManager.On("Path", mock.Anything).Return("")
mockManager.On("Set", mock.Anything).Return(nil)
mockManager.On("GetPaths").Return(map[string]string{})
mockManager.On("GetCgroups").Return(nil, nil)
mockManager.On("GetFreezerState").Return("", nil)
mockManager.On("Exists").Return(false)
mockManager.On("OOMKillCount").Return(0, nil)

cgroup := &cgroup.CGroup{
Manager: &MockCgroupManager{},
Manager: mockManager,
}

has, err := cgroup.HasProcess()
Expand All @@ -79,7 +108,7 @@ func TestCgroup(t *testing.T) {
funcs, err := cgroup.CreateStats()
require.NoError(t, err)
require.NotEmpty(t, funcs)
require.Len(t, funcs, 4)
require.Len(t, funcs, 5)

var buffer bytes.Buffer
_, err = cgroup.Marshal(&buffer)
Expand Down
62 changes: 52 additions & 10 deletions internal/cgroup/parser/parser.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,15 @@ package parser
import (
"bytes"
"math"
"strings"
"syscall"
"time"

"github.com/opencontainers/runc/libcontainer/cgroups"
)

type Marshal interface {
Marshal(*bytes.Buffer) (*bytes.Buffer, error)
Marshal(buffer *bytes.Buffer) (*bytes.Buffer, error)
}

type StatManager struct {
Expand All @@ -30,7 +31,7 @@ func (s *StatManager) add(fc StatFunc) *StatManager {
}

func (s *StatManager) WithCPU() *StatManager {
return s.add(func() (string, float64) {
return s.add(func() map[string]float64 {
nowTime := time.Now()

curTime := uint64(nowTime.UnixNano())
Expand All @@ -48,12 +49,16 @@ func (s *StatManager) WithCPU() *StatManager {
// update the saved metrics
s.prevTime = curTime
s.prevCPU = curCPU
return "cpu_usage", cpuPercent
return map[string]float64{
"cpu_usage_per": cpuPercent,
"cpu_prevTime": float64(s.prevTime),
"cpu_prevCpu": float64(s.prevCPU),
}
})
}

func (s *StatManager) WithMemory() *StatManager {
return s.add(func() (string, float64) {
return s.add(func() map[string]float64 {
memUsage := s.MemoryStats.Usage.Usage
memLimit := s.MemoryStats.Usage.Limit
memPercent := 0.0
Expand All @@ -69,12 +74,16 @@ func (s *StatManager) WithMemory() *StatManager {
if memLimit != 0 {
memPercent = float64(memUsage) / float64(memLimit) * 100.0
}
return "memory_usage", memPercent
return map[string]float64{
"memory_usage_per": memPercent,
"memory_usage": float64(memUsage),
"memory_limit": float64(memLimit),
}
})
}

func (s *StatManager) WithMemorySwap() *StatManager {
return s.add(func() (string, float64) {
return s.add(func() map[string]float64 {
swapUsage := s.MemoryStats.SwapUsage.Usage
swapLimit := s.MemoryStats.SwapUsage.Limit
swapPercent := 0.0
Expand All @@ -90,21 +99,54 @@ func (s *StatManager) WithMemorySwap() *StatManager {
if swapLimit != 0 {
swapPercent = float64(swapUsage) / float64(swapLimit) * 100.0
}
return "memory_swap_usage", swapPercent
return map[string]float64{
"memory_swap_usage_per": swapPercent,
"memory_swap": float64(swapUsage),
"memory_swap_limit": float64(swapLimit),
}
})
}

func (s *StatManager) WithPid() *StatManager {
return s.add(func() (string, float64) {
return "pid_usage", float64(s.PidsStats.Current)
return s.add(func() map[string]float64 {
pidUsage := s.PidsStats.Current
pidLimit := s.PidsStats.Limit
pidPercent := 0.0

if pidLimit != 0 {
pidPercent = float64(pidUsage) / float64(pidLimit) * 100.0
}
return map[string]float64{
"pid_usage_per": pidPercent,
"pid_usage": float64(pidUsage),
"pid_limit": float64(pidLimit),
}
})
}

func (s *StatManager) WithBlkIO() *StatManager {
return s.add(func() map[string]float64 {
var read, write float64
for _, entry := range s.BlkioStats.IoQueuedRecursive {
switch strings.ToLower(entry.Op) {
case "read":
read += float64(entry.Value)
case "write":
write += float64(entry.Value)
}
}
return map[string]float64{
"blkio_read": read,
"blkio_write": write,
}
})
}

func (s *StatManager) All() []StatFunc {
return s.funcs
}

type StatFunc func() (string, float64)
type StatFunc func() map[string]float64

type Stat interface {
CreateStats() ([]StatFunc, error)
Expand Down
Loading

0 comments on commit 81d0a53

Please sign in to comment.