From c0374ef2d6a36552f05fcd920d3ca945ec83ad66 Mon Sep 17 00:00:00 2001 From: zwzhang Date: Mon, 26 Feb 2024 20:54:35 +0800 Subject: [PATCH] koordlet: add metrics for kubelet and resource executor (#1913) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: 佑祎 --- pkg/koordlet/metrics/internal_metrics.go | 2 + pkg/koordlet/metrics/kubelet.go | 59 +++++++++++++++++++ pkg/koordlet/metrics/metrics_test.go | 22 +++---- pkg/koordlet/metrics/psi.go | 10 ++-- pkg/koordlet/metrics/psi_test.go | 22 +++---- pkg/koordlet/metrics/resource_executor.go | 51 ++++++++++++++++ .../performance_collector_linux_test.go | 4 +- pkg/koordlet/resourceexecutor/executor.go | 19 ++++-- pkg/koordlet/resourceexecutor/reader.go | 14 ++--- .../resourceexecutor/resctrl_updater.go | 4 ++ pkg/koordlet/resourceexecutor/updater.go | 15 +++-- .../statesinformer/impl/kubelet_stub.go | 14 ++++- .../{resourceexecutor => util/system}/psi.go | 4 +- .../system}/psi_test.go | 28 ++++----- 14 files changed, 202 insertions(+), 66 deletions(-) create mode 100644 pkg/koordlet/metrics/kubelet.go create mode 100644 pkg/koordlet/metrics/resource_executor.go rename pkg/koordlet/{resourceexecutor => util/system}/psi.go (96%) rename pkg/koordlet/{resourceexecutor => util/system}/psi_test.go (87%) diff --git a/pkg/koordlet/metrics/internal_metrics.go b/pkg/koordlet/metrics/internal_metrics.go index 65c58d69f..b049ed337 100644 --- a/pkg/koordlet/metrics/internal_metrics.go +++ b/pkg/koordlet/metrics/internal_metrics.go @@ -41,4 +41,6 @@ func init() { internalMustRegister(CPUBurstCollector...) internalMustRegister(PredictionCollectors...) internalMustRegister(CoreSchedCollector...) + internalMustRegister(ResourceExecutorCollector...) + internalMustRegister(KubeletStubCollector...) } diff --git a/pkg/koordlet/metrics/kubelet.go b/pkg/koordlet/metrics/kubelet.go new file mode 100644 index 000000000..5b2548bde --- /dev/null +++ b/pkg/koordlet/metrics/kubelet.go @@ -0,0 +1,59 @@ +/* +Copyright 2022 The Koordinator Authors. + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ + +package metrics + +import ( + "time" + + "github.com/prometheus/client_golang/prometheus" +) + +const ( + HTTPVerbKey = "verb" + HTTPPathKey = "path" + HTTPCodeKey = "code" +) + +const ( + HTTPVerbGet = "get" +) + +var ( + kubeletRequestDurationSeconds = prometheus.NewHistogramVec( + prometheus.HistogramOpts{ + Subsystem: KoordletSubsystem, + Name: "kubelet_request_duration_seconds", + Help: "kubelet http request duration in seconds", + // 10s ~ 4s, /config <= 4ms, /pods <= 16ms + Buckets: prometheus.ExponentialBuckets(0.001, 4, 7), + }, + []string{HTTPVerbKey, HTTPPathKey, HTTPCodeKey}, + ) + + KubeletStubCollector = []prometheus.Collector{ + kubeletRequestDurationSeconds, + } +) + +// RecordKubeletRequestDuration records the duration of kubelet http request +func RecordKubeletRequestDuration(verb, path, code string, seconds float64) { + kubeletRequestDurationSeconds.WithLabelValues(verb, path, code).Observe(seconds) +} + +func SinceInSeconds(start time.Time) float64 { + return time.Since(start).Seconds() +} diff --git a/pkg/koordlet/metrics/metrics_test.go b/pkg/koordlet/metrics/metrics_test.go index c27f45c49..998ea477a 100644 --- a/pkg/koordlet/metrics/metrics_test.go +++ b/pkg/koordlet/metrics/metrics_test.go @@ -28,7 +28,7 @@ import ( apiext "github.com/koordinator-sh/koordinator/apis/extension" slov1alpha1 "github.com/koordinator-sh/koordinator/apis/slo/v1alpha1" - "github.com/koordinator-sh/koordinator/pkg/koordlet/resourceexecutor" + "github.com/koordinator-sh/koordinator/pkg/koordlet/util/system" "github.com/koordinator-sh/koordinator/pkg/util" ) @@ -77,15 +77,15 @@ func TestCommonCollectors(t *testing.T) { UID: "test01", }, } - testingPSI := &resourceexecutor.PSIByResource{ - CPU: resourceexecutor.PSIStats{ - Some: &resourceexecutor.PSILine{ + testingPSI := &system.PSIByResource{ + CPU: system.PSIStats{ + Some: &system.PSILine{ Avg10: 1, Avg60: 1, Avg300: 1, Total: 1, }, - Full: &resourceexecutor.PSILine{ + Full: &system.PSILine{ Avg10: 1, Avg60: 1, Avg300: 1, @@ -93,14 +93,14 @@ func TestCommonCollectors(t *testing.T) { }, FullSupported: true, }, - Mem: resourceexecutor.PSIStats{ - Some: &resourceexecutor.PSILine{ + Mem: system.PSIStats{ + Some: &system.PSILine{ Avg10: 1, Avg60: 1, Avg300: 1, Total: 1, }, - Full: &resourceexecutor.PSILine{ + Full: &system.PSILine{ Avg10: 1, Avg60: 1, Avg300: 1, @@ -108,14 +108,14 @@ func TestCommonCollectors(t *testing.T) { }, FullSupported: true, }, - IO: resourceexecutor.PSIStats{ - Some: &resourceexecutor.PSILine{ + IO: system.PSIStats{ + Some: &system.PSILine{ Avg10: 1, Avg60: 1, Avg300: 1, Total: 1, }, - Full: &resourceexecutor.PSILine{ + Full: &system.PSILine{ Avg10: 1, Avg60: 1, Avg300: 1, diff --git a/pkg/koordlet/metrics/psi.go b/pkg/koordlet/metrics/psi.go index 5ba07f6fc..b8d1e6d94 100644 --- a/pkg/koordlet/metrics/psi.go +++ b/pkg/koordlet/metrics/psi.go @@ -22,7 +22,7 @@ import ( "github.com/prometheus/client_golang/prometheus" corev1 "k8s.io/api/core/v1" - "github.com/koordinator-sh/koordinator/pkg/koordlet/resourceexecutor" + "github.com/koordinator-sh/koordinator/pkg/koordlet/util/system" ) const ( @@ -73,7 +73,7 @@ type PSIRecord struct { CPUFullSupported bool } -func getPSIRecords(psi *resourceexecutor.PSIByResource) []PSIRecord { +func getPSIRecords(psi *system.PSIByResource) []PSIRecord { var psiRecordAll []PSIRecord psiRecordAll = append(psiRecordAll, makePSIRecordSlice(ResourceTypeCPU, psi.CPU)...) psiRecordAll = append(psiRecordAll, makePSIRecordSlice(ResourceTypeMem, psi.Mem)...) @@ -81,7 +81,7 @@ func getPSIRecords(psi *resourceexecutor.PSIByResource) []PSIRecord { return psiRecordAll } -func makePSIRecordSlice(resourceType string, psiStats resourceexecutor.PSIStats) []PSIRecord { +func makePSIRecordSlice(resourceType string, psiStats system.PSIStats) []PSIRecord { records := []PSIRecord{ { ResourceType: resourceType, @@ -134,7 +134,7 @@ func makePSIRecordSlice(resourceType string, psiStats resourceexecutor.PSIStats) return records } -func RecordContainerPSI(status *corev1.ContainerStatus, pod *corev1.Pod, psi *resourceexecutor.PSIByResource) { +func RecordContainerPSI(status *corev1.ContainerStatus, pod *corev1.Pod, psi *system.PSIByResource) { psiRecords := getPSIRecords(psi) for _, record := range psiRecords { labels := genNodeLabels() @@ -155,7 +155,7 @@ func RecordContainerPSI(status *corev1.ContainerStatus, pod *corev1.Pod, psi *re } } -func RecordPodPSI(pod *corev1.Pod, psi *resourceexecutor.PSIByResource) { +func RecordPodPSI(pod *corev1.Pod, psi *system.PSIByResource) { psiRecords := getPSIRecords(psi) for _, record := range psiRecords { labels := genNodeLabels() diff --git a/pkg/koordlet/metrics/psi_test.go b/pkg/koordlet/metrics/psi_test.go index 27f2c11c9..774e065d1 100644 --- a/pkg/koordlet/metrics/psi_test.go +++ b/pkg/koordlet/metrics/psi_test.go @@ -21,24 +21,24 @@ import ( "github.com/stretchr/testify/assert" - "github.com/koordinator-sh/koordinator/pkg/koordlet/resourceexecutor" + "github.com/koordinator-sh/koordinator/pkg/koordlet/util/system" ) func TestGetPSIRecords(t *testing.T) { - testingRecords := &resourceexecutor.PSIByResource{ - CPU: resourceexecutor.PSIStats{ - Some: &resourceexecutor.PSILine{}, - Full: &resourceexecutor.PSILine{}, + testingRecords := &system.PSIByResource{ + CPU: system.PSIStats{ + Some: &system.PSILine{}, + Full: &system.PSILine{}, FullSupported: true, }, - Mem: resourceexecutor.PSIStats{ - Some: &resourceexecutor.PSILine{}, - Full: &resourceexecutor.PSILine{}, + Mem: system.PSIStats{ + Some: &system.PSILine{}, + Full: &system.PSILine{}, FullSupported: true, }, - IO: resourceexecutor.PSIStats{ - Some: &resourceexecutor.PSILine{}, - Full: &resourceexecutor.PSILine{}, + IO: system.PSIStats{ + Some: &system.PSILine{}, + Full: &system.PSILine{}, FullSupported: true, }, } diff --git a/pkg/koordlet/metrics/resource_executor.go b/pkg/koordlet/metrics/resource_executor.go new file mode 100644 index 000000000..cb75b4ff9 --- /dev/null +++ b/pkg/koordlet/metrics/resource_executor.go @@ -0,0 +1,51 @@ +/* +Copyright 2022 The Koordinator Authors. + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ + +package metrics + +import ( + "github.com/prometheus/client_golang/prometheus" +) + +const ( + // ResourceUpdaterType represents the type of resource udpater, including cgroup files, resctrl files, etc + ResourceUpdaterType = "type" + // ResourceUpdateStatusKey represents the status of resource update + ResourceUpdateStatusKey = "status" +) + +const ( + ResourceUpdateStatusSuccess = "success" + ResourceUpdateStatusFailed = "failed" +) + +var ( + resourceUpdateDurationMilliSeconds = prometheus.NewHistogramVec(prometheus.HistogramOpts{ + Subsystem: KoordletSubsystem, + Name: "resource_update_duration_milliseconds", + Help: "time duration of resource update such as cgroup files", + // 10us ~ 10.24ms, cgroup <= 40us + Buckets: prometheus.ExponentialBuckets(0.01, 4, 8), + }, []string{ResourceUpdaterType, ResourceUpdateStatusKey}) + + ResourceExecutorCollector = []prometheus.Collector{ + resourceUpdateDurationMilliSeconds, + } +) + +func RecordResourceUpdateDuration(updaterType, status string, seconds float64) { + resourceUpdateDurationMilliSeconds.WithLabelValues(updaterType, status).Observe(seconds * 1000) +} diff --git a/pkg/koordlet/metricsadvisor/collectors/performance/performance_collector_linux_test.go b/pkg/koordlet/metricsadvisor/collectors/performance/performance_collector_linux_test.go index 81899e2fd..9cdce87fc 100644 --- a/pkg/koordlet/metricsadvisor/collectors/performance/performance_collector_linux_test.go +++ b/pkg/koordlet/metricsadvisor/collectors/performance/performance_collector_linux_test.go @@ -404,8 +404,8 @@ func mockLSPod() *corev1.Pod { // Mem: /sys/fs/cgroup/cpu/kubepods.slice/kubepods-burstable.slice/kubepods-pod7712555c_ce62_454a_9e18_9ff0217b8941.slice/memory.pressure // IO: /sys/fs/cgroup/cpu/kubepods.slice/kubepods-burstable.slice/kubepods-pod7712555c_ce62_454a_9e18_9ff0217b8941.slice/io.pressure // } -func getPodCgroupCPUAcctPSIPath(podParentDir string) resourceexecutor.PSIPath { - return resourceexecutor.PSIPath{ +func getPodCgroupCPUAcctPSIPath(podParentDir string) system.PSIPath { + return system.PSIPath{ CPU: system.GetCgroupFilePath(podParentDir, system.CPUAcctCPUPressure), Mem: system.GetCgroupFilePath(podParentDir, system.CPUAcctMemoryPressure), IO: system.GetCgroupFilePath(podParentDir, system.CPUAcctIOPressure), diff --git a/pkg/koordlet/resourceexecutor/executor.go b/pkg/koordlet/resourceexecutor/executor.go index 40f73c49b..b53b4de3d 100644 --- a/pkg/koordlet/resourceexecutor/executor.go +++ b/pkg/koordlet/resourceexecutor/executor.go @@ -23,6 +23,7 @@ import ( "k8s.io/klog/v2" + "github.com/koordinator-sh/koordinator/pkg/koordlet/metrics" sysutil "github.com/koordinator-sh/koordinator/pkg/koordlet/util/system" "github.com/koordinator-sh/koordinator/pkg/util/cache" ) @@ -220,30 +221,36 @@ func (e *ResourceUpdateExecutorImpl) needUpdate(updater ResourceUpdater) bool { } func (e *ResourceUpdateExecutorImpl) update(updater ResourceUpdater) error { + start := time.Now() err := updater.update() - if err != nil && e.isUpdateErrIgnored(err) { - klog.V(5).Infof("failed to update resource %s to %v, ignored err: %v", updater.Key(), updater.Value(), err) - return nil - } - if err != nil { + if err != nil && !e.isUpdateErrIgnored(err) { + metrics.RecordResourceUpdateDuration(updater.Name(), metrics.ResourceUpdateStatusFailed, metrics.SinceInSeconds(start)) klog.V(5).Infof("failed to update resource %s to %v, err: %v", updater.Key(), updater.Value(), err) return err + } else if err != nil { + // error can be ignored + klog.V(5).Infof("failed to update resource %s to %v, ignored err: %v", updater.Key(), updater.Value(), err) + } else { + metrics.RecordResourceUpdateDuration(updater.Name(), metrics.ResourceUpdateStatusSuccess, metrics.SinceInSeconds(start)) + klog.V(6).Infof("successfully update resource %s to %v", updater.Key(), updater.Value()) } - klog.V(6).Infof("successfully update resource %s to %v", updater.Key(), updater.Value()) return nil } func (e *ResourceUpdateExecutorImpl) updateByCache(updater ResourceUpdater) (bool, error) { if e.needUpdate(updater) { + start := time.Now() err := updater.update() if err != nil && e.isUpdateErrIgnored(err) { klog.V(5).Infof("failed to cacheable update resource %s to %v, ignored err: %v", updater.Key(), updater.Value(), err) return false, nil } if err != nil { + metrics.RecordResourceUpdateDuration(updater.Name(), metrics.ResourceUpdateStatusFailed, metrics.SinceInSeconds(start)) klog.V(5).Infof("failed to cacheable update resource %s to %v, err: %v", updater.Key(), updater.Value(), err) return false, err } + metrics.RecordResourceUpdateDuration(updater.Name(), metrics.ResourceUpdateStatusSuccess, metrics.SinceInSeconds(start)) updater.UpdateLastUpdateTimestamp(time.Now()) err = e.ResourceCache.SetDefault(updater.Key(), updater) if err != nil { diff --git a/pkg/koordlet/resourceexecutor/reader.go b/pkg/koordlet/resourceexecutor/reader.go index d19068eb5..dfe68cc64 100644 --- a/pkg/koordlet/resourceexecutor/reader.go +++ b/pkg/koordlet/resourceexecutor/reader.go @@ -38,7 +38,7 @@ type CgroupReader interface { ReadMemoryNumaStat(parentDir string) ([]sysutil.NumaMemoryPages, error) ReadCPUTasks(parentDir string) ([]int32, error) ReadCPUProcs(parentDir string) ([]uint32, error) - ReadPSI(parentDir string) (*PSIByResource, error) + ReadPSI(parentDir string) (*sysutil.PSIByResource, error) ReadMemoryColdPageUsage(parentDir string) (uint64, error) } @@ -204,7 +204,7 @@ func (r *CgroupV1Reader) ReadCPUProcs(parentDir string) ([]uint32, error) { return sysutil.ParseCgroupProcs(s) } -func (r *CgroupV1Reader) ReadPSI(parentDir string) (*PSIByResource, error) { +func (r *CgroupV1Reader) ReadPSI(parentDir string) (*sysutil.PSIByResource, error) { cpuPressureResource, ok := sysutil.DefaultRegistry.Get(sysutil.CgroupVersionV1, sysutil.CPUAcctCPUPressureName) if !ok { return nil, ErrResourceNotRegistered @@ -218,12 +218,12 @@ func (r *CgroupV1Reader) ReadPSI(parentDir string) (*PSIByResource, error) { return nil, ErrResourceNotRegistered } - paths := PSIPath{ + paths := sysutil.PSIPath{ CPU: cpuPressureResource.Path(parentDir), Mem: memPressureResource.Path(parentDir), IO: ioPressureResource.Path(parentDir), } - psi, err := getPSIByResource(paths) + psi, err := sysutil.GetPSIByResource(paths) if err != nil { return nil, err } @@ -410,7 +410,7 @@ func (r *CgroupV2Reader) ReadCPUProcs(parentDir string) ([]uint32, error) { return sysutil.ParseCgroupProcs(s) } -func (r *CgroupV2Reader) ReadPSI(parentDir string) (*PSIByResource, error) { +func (r *CgroupV2Reader) ReadPSI(parentDir string) (*sysutil.PSIByResource, error) { cpuPressureResource, ok := sysutil.DefaultRegistry.Get(sysutil.CgroupVersionV2, sysutil.CPUAcctCPUPressureName) if !ok { return nil, ErrResourceNotRegistered @@ -424,12 +424,12 @@ func (r *CgroupV2Reader) ReadPSI(parentDir string) (*PSIByResource, error) { return nil, ErrResourceNotRegistered } - paths := PSIPath{ + paths := sysutil.PSIPath{ CPU: cpuPressureResource.Path(parentDir), Mem: memPressureResource.Path(parentDir), IO: ioPressureResource.Path(parentDir), } - psi, err := getPSIByResource(paths) + psi, err := sysutil.GetPSIByResource(paths) if err != nil { return nil, err } diff --git a/pkg/koordlet/resourceexecutor/resctrl_updater.go b/pkg/koordlet/resourceexecutor/resctrl_updater.go index 42038b0a0..ba8a19b63 100644 --- a/pkg/koordlet/resourceexecutor/resctrl_updater.go +++ b/pkg/koordlet/resourceexecutor/resctrl_updater.go @@ -36,6 +36,10 @@ type ResctrlSchemataResourceUpdater struct { schemataRaw *sysutil.ResctrlSchemataRaw } +func (r *ResctrlSchemataResourceUpdater) Name() string { + return "resctrl-schema" +} + func (r *ResctrlSchemataResourceUpdater) Key() string { return r.schemataRaw.Prefix() + r.file } diff --git a/pkg/koordlet/resourceexecutor/updater.go b/pkg/koordlet/resourceexecutor/updater.go index 4a2a8f939..896c6024c 100644 --- a/pkg/koordlet/resourceexecutor/updater.go +++ b/pkg/koordlet/resourceexecutor/updater.go @@ -84,6 +84,8 @@ type UpdateFunc func(resource ResourceUpdater) error type MergeUpdateFunc func(resource ResourceUpdater) (ResourceUpdater, error) type ResourceUpdater interface { + // Name returns the name of the resource updater + Name() string ResourceType() sysutil.ResourceType Key() string Path() string @@ -112,6 +114,10 @@ type CgroupResourceUpdater struct { eventHelper *audit.EventHelper } +func (u *CgroupResourceUpdater) Name() string { + return "cgroup" +} + func (u *CgroupResourceUpdater) ResourceType() sysutil.ResourceType { return u.file.ResourceType() } @@ -186,6 +192,10 @@ type DefaultResourceUpdater struct { eventHelper *audit.EventHelper } +func (u *DefaultResourceUpdater) Name() string { + return "default" +} + func (u *DefaultResourceUpdater) ResourceType() sysutil.ResourceType { return sysutil.ResourceType(u.file) } @@ -245,11 +255,6 @@ func NewCommonDefaultUpdaterWithUpdateFunc(key string, file string, value string }, nil } -type GuestCgroupResourceUpdater struct { - *CgroupResourceUpdater - sandboxID string // for execute the file operation inside the sandbox -} - type NewResourceUpdaterFunc func(resourceType sysutil.ResourceType, parentDir string, value string, e *audit.EventHelper) (ResourceUpdater, error) type ResourceUpdaterFactory interface { diff --git a/pkg/koordlet/statesinformer/impl/kubelet_stub.go b/pkg/koordlet/statesinformer/impl/kubelet_stub.go index fca401c04..ae7a4b4e3 100644 --- a/pkg/koordlet/statesinformer/impl/kubelet_stub.go +++ b/pkg/koordlet/statesinformer/impl/kubelet_stub.go @@ -33,6 +33,8 @@ import ( "k8s.io/kubernetes/cmd/kubelet/app/options" kubeletconfiginternal "k8s.io/kubernetes/pkg/kubelet/apis/config" kubeletscheme "k8s.io/kubernetes/pkg/kubelet/apis/config/scheme" + + "github.com/koordinator-sh/koordinator/pkg/koordlet/metrics" ) type KubeletStub interface { @@ -68,13 +70,17 @@ func NewKubeletStub(addr string, port int, scheme string, timeout time.Duration, } func (k *kubeletStub) GetAllPods() (corev1.PodList, error) { + path := "/pods/" url := url.URL{ Scheme: k.scheme, Host: net.JoinHostPort(k.addr, strconv.Itoa(k.port)), - Path: "/pods/", + Path: path, } podList := corev1.PodList{} + start := time.Now() rsp, err := k.httpClient.Get(url.String()) + metrics.RecordKubeletRequestDuration(metrics.HTTPVerbGet, path, strconv.Itoa(rsp.StatusCode), metrics.SinceInSeconds(start)) + if err != nil { return podList, err } @@ -102,12 +108,16 @@ type kubeletConfigz struct { // GetKubeletConfiguration removes the logging field from the configz during unmarshall to make sure the configz is compatible func (k *kubeletStub) GetKubeletConfiguration() (*kubeletconfiginternal.KubeletConfiguration, error) { + path := "/configz" configzURL := url.URL{ Scheme: k.scheme, Host: net.JoinHostPort(k.addr, strconv.Itoa(k.port)), - Path: "/configz", + Path: path, } + start := time.Now() rsp, err := k.httpClient.Get(configzURL.String()) + metrics.RecordKubeletRequestDuration(metrics.HTTPVerbGet, path, strconv.Itoa(rsp.StatusCode), metrics.SinceInSeconds(start)) + if err != nil { return nil, err } diff --git a/pkg/koordlet/resourceexecutor/psi.go b/pkg/koordlet/util/system/psi.go similarity index 96% rename from pkg/koordlet/resourceexecutor/psi.go rename to pkg/koordlet/util/system/psi.go index b4016aa85..411f82854 100644 --- a/pkg/koordlet/resourceexecutor/psi.go +++ b/pkg/koordlet/util/system/psi.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -package resourceexecutor +package system import ( "bufio" @@ -93,7 +93,7 @@ func ParsePSIStats(r io.Reader) (PSIStats, error) { return psiStats, nil } -func getPSIByResource(paths PSIPath) (*PSIByResource, error) { +func GetPSIByResource(paths PSIPath) (*PSIByResource, error) { cpuStats, err := readPSI(paths.CPU) if err != nil { return nil, err diff --git a/pkg/koordlet/resourceexecutor/psi_test.go b/pkg/koordlet/util/system/psi_test.go similarity index 87% rename from pkg/koordlet/resourceexecutor/psi_test.go rename to pkg/koordlet/util/system/psi_test.go index 891bec471..cb572af38 100644 --- a/pkg/koordlet/resourceexecutor/psi_test.go +++ b/pkg/koordlet/util/system/psi_test.go @@ -14,15 +14,13 @@ See the License for the specific language governing permissions and limitations under the License. */ -package resourceexecutor +package system import ( "path" "testing" "github.com/stretchr/testify/assert" - - sysutil "github.com/koordinator-sh/koordinator/pkg/koordlet/util/system" ) const ( @@ -37,7 +35,7 @@ func TestGetPSIByResource_CPUErr(t *testing.T) { IO: path.Join(dir, "io.pressure"), } assert.NotPanics(t, func() { - _, err := getPSIByResource(psiPath) + _, err := GetPSIByResource(psiPath) if err != nil { return } @@ -45,7 +43,7 @@ func TestGetPSIByResource_CPUErr(t *testing.T) { } func TestGetPSIByResource_MemErr(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", FullCorrectPSIContents) psiPath := PSIPath{ @@ -54,7 +52,7 @@ func TestGetPSIByResource_MemErr(t *testing.T) { IO: path.Join(helper.TempDir, "io.pressure"), } assert.NotPanics(t, func() { - _, err := getPSIByResource(psiPath) + _, err := GetPSIByResource(psiPath) if err != nil { return } @@ -62,7 +60,7 @@ func TestGetPSIByResource_MemErr(t *testing.T) { } func TestGetPSIByResource_IOErr(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", FullCorrectPSIContents) helper.CreateFile("memory.pressure") @@ -73,7 +71,7 @@ func TestGetPSIByResource_IOErr(t *testing.T) { IO: path.Join(helper.TempDir, "io.pressure"), } assert.NotPanics(t, func() { - _, err := getPSIByResource(psiPath) + _, err := GetPSIByResource(psiPath) if err != nil { return } @@ -81,7 +79,7 @@ func TestGetPSIByResource_IOErr(t *testing.T) { } func TestGetPSIByResource(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", FullCorrectPSIContents) helper.CreateFile("memory.pressure") @@ -94,7 +92,7 @@ func TestGetPSIByResource(t *testing.T) { IO: path.Join(helper.TempDir, "io.pressure"), } assert.NotPanics(t, func() { - _, err := getPSIByResource(psiPath) + _, err := GetPSIByResource(psiPath) if err != nil { return } @@ -102,7 +100,7 @@ func TestGetPSIByResource(t *testing.T) { } func TestGetPSIRecords(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", "some avg10=0.00 avg60=0.00 avg300=0.00 total=0\nfull avg10=0.00 avg60=0.00 avg300=0.00 total=0") @@ -115,7 +113,7 @@ func TestGetPSIRecords(t *testing.T) { } func TestGetPSIRecords_wrongSomeFormat(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", "some avg10=0.00 total=0\nfull avg10=0.00 avg60=0.00 avg300=0.00 total=0") @@ -124,7 +122,7 @@ func TestGetPSIRecords_wrongSomeFormat(t *testing.T) { } func TestGetPSIRecords_wrongFullFormat(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", "some avg10=0.00 total=0\nfull 0.00 avg300=0.00 total=0") @@ -133,7 +131,7 @@ func TestGetPSIRecords_wrongFullFormat(t *testing.T) { } func TestGetPSIRecords_wrongPrefix(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", "wrong avg10=0.00 total=0\nfull 0.00 avg300=0.00 total=0") @@ -142,7 +140,7 @@ func TestGetPSIRecords_wrongPrefix(t *testing.T) { } func TestGetPSIRecords_FullNotSupported(t *testing.T) { - helper := sysutil.NewFileTestUtil(t) + helper := NewFileTestUtil(t) helper.CreateFile("cpu.pressure") helper.WriteFileContents("cpu.pressure", "some avg10=0.00 avg60=0.00 avg300=0.00 total=0\n")