From 37295102c53b75845e23cb11e976d47c11137e2f Mon Sep 17 00:00:00 2001 From: "omri.s" Date: Sun, 22 Dec 2024 12:24:42 +0200 Subject: [PATCH] CPU consumption improvement - Run `populateReferencedKubernetesServices` only if egress is enabled --- src/operator/effectivepolicy/groupreconciler.go | 12 ++++++++---- src/operator/effectivepolicy/types.go | 2 ++ 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/src/operator/effectivepolicy/groupreconciler.go b/src/operator/effectivepolicy/groupreconciler.go index 435df5faf..a21fb332a 100644 --- a/src/operator/effectivepolicy/groupreconciler.go +++ b/src/operator/effectivepolicy/groupreconciler.go @@ -8,6 +8,7 @@ import ( "github.com/otterize/intents-operator/src/operator/controllers/access_annotation" "github.com/otterize/intents-operator/src/shared/errors" "github.com/otterize/intents-operator/src/shared/injectablerecorder" + "github.com/otterize/intents-operator/src/shared/operatorconfig/enforcement" "github.com/otterize/intents-operator/src/shared/serviceidresolver" "github.com/otterize/intents-operator/src/shared/serviceidresolver/serviceidentity" "github.com/samber/lo" @@ -30,6 +31,7 @@ type GroupReconciler struct { Scheme *runtime.Scheme reconcilers []reconciler serviceIdResolver *serviceidresolver.Resolver + egressEnabled bool injectablerecorder.InjectableRecorder } @@ -39,6 +41,7 @@ func NewGroupReconciler(k8sClient client.Client, scheme *runtime.Scheme, service Scheme: scheme, serviceIdResolver: serviceIdResolver, reconcilers: reconcilers, + egressEnabled: enforcement.GetConfig().EnableEgressNetworkPolicyReconcilers, } } @@ -183,10 +186,11 @@ func (g *GroupReconciler) buildServiceEffectivePolicy( for _, intent := range clientIntents.GetTargetList() { serversFoundInClientIntents.Add(intent.ToServiceIdentity(clientIntents.Namespace)) call := Call{Target: intent, EventRecorder: recorder} - - call, err = g.populateReferencedKubernetesServices(ctx, call, clientIntents, intent) - if err != nil { - return ServiceEffectivePolicy{}, errors.Wrap(err) + if g.egressEnabled { + call, err = g.populateReferencedKubernetesServices(ctx, call, clientIntents, intent) + if err != nil { + return ServiceEffectivePolicy{}, errors.Wrap(err) + } } calls = append(calls, call) diff --git a/src/operator/effectivepolicy/types.go b/src/operator/effectivepolicy/types.go index 643dcc7a3..c3330575b 100644 --- a/src/operator/effectivepolicy/types.go +++ b/src/operator/effectivepolicy/types.go @@ -16,6 +16,8 @@ type ClientCall struct { type Call struct { v2alpha1.Target + // This is here as a workaround to make egress policies work in AWS VPC CNI which requires a rule matching the service's selector exactly in order to allow traffic to ClusterIP. + // it will be populated only if egress is enabled ReferencingKubernetesServices []v1.Service EventRecorder *injectablerecorder.ObjectEventRecorder }