From 16688dcdbb0bd6c25ca1417b10d801b2c1edbe50 Mon Sep 17 00:00:00 2001 From: Mahmoud Atwa Date: Thu, 3 Oct 2024 12:07:08 +0000 Subject: [PATCH] Adds injection metrics for fake pod injection --- .../enforce_injected_pods_limit_processor.go | 23 ++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) diff --git a/cluster-autoscaler/processors/podinjection/enforce_injected_pods_limit_processor.go b/cluster-autoscaler/processors/podinjection/enforce_injected_pods_limit_processor.go index 1c674401a953..9cd6e1ad5704 100644 --- a/cluster-autoscaler/processors/podinjection/enforce_injected_pods_limit_processor.go +++ b/cluster-autoscaler/processors/podinjection/enforce_injected_pods_limit_processor.go @@ -19,6 +19,15 @@ package podinjection import ( apiv1 "k8s.io/api/core/v1" "k8s.io/autoscaler/cluster-autoscaler/context" + "k8s.io/autoscaler/cluster-autoscaler/metrics" +) + +const ( + + // InjectedMetricsLabel is the label for unschedulable pods metric for injected pods. + InjectedMetricsLabel = "injected" + // SkippedInjectionMetricsLabel is the label for unschedulable pods metric for pods that was not injected due to limit. + SkippedInjectionMetricsLabel = "skipped_injection" ) // EnforceInjectedPodsLimitProcessor is a PodListProcessor used to limit the number of injected fake pods. @@ -37,17 +46,25 @@ func NewEnforceInjectedPodsLimitProcessor(podLimit int) *EnforceInjectedPodsLimi func (p *EnforceInjectedPodsLimitProcessor) Process(ctx *context.AutoscalingContext, unschedulablePods []*apiv1.Pod) ([]*apiv1.Pod, error) { numberOfFakePodsToRemove := len(unschedulablePods) - p.podLimit + removedFakePodsCount := 0 + injectedFakePodsCount := 0 var unschedulablePodsAfterProcessing []*apiv1.Pod for _, pod := range unschedulablePods { - if IsFake(pod) && numberOfFakePodsToRemove > 0 { - numberOfFakePodsToRemove -= 1 - continue + if IsFake(pod) { + injectedFakePodsCount += 1 + if removedFakePodsCount < numberOfFakePodsToRemove { + removedFakePodsCount += 1 + continue + } } unschedulablePodsAfterProcessing = append(unschedulablePodsAfterProcessing, pod) } + metrics.UpdateUnschedulablePodsCountWithLabel(injectedFakePodsCount, InjectedMetricsLabel) + metrics.UpdateUnschedulablePodsCountWithLabel(removedFakePodsCount, SkippedInjectionMetricsLabel) + return unschedulablePodsAfterProcessing, nil }