Skip to content

Commit

Permalink
skip publishing empty status for policies (#2902)
Browse files Browse the repository at this point in the history
* skip publishing empty status for policies

* #2802 skips computing status
if a target resource cannot be found, mainly because that target maybe
irrelevant to this specific translation, its hard to proactively find
that out in the provider layer

* This fix ensures that any empty status is not published and resets any
existing status for a policy

Signed-off-by: Arko Dasgupta <[email protected]>

* also fix for envoypatchpolicy

Signed-off-by: Arko Dasgupta <[email protected]>

* also discard status for backendtlspolicy

Signed-off-by: Arko Dasgupta <[email protected]>

---------

Signed-off-by: Arko Dasgupta <[email protected]>
  • Loading branch information
arkodg authored Mar 13, 2024
1 parent bb0a9a7 commit 45f52e8
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 9 deletions.
22 changes: 18 additions & 4 deletions internal/gatewayapi/runner/runner.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ package runner

import (
"context"
"reflect"

"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/apimachinery/pkg/types"
Expand Down Expand Up @@ -156,29 +157,42 @@ func (r *Runner) subscribeAndTranslate(ctx context.Context) {
r.ProviderResources.UDPRouteStatuses.Store(key, &udpRoute.Status)
delete(statusesToDelete.UDPRouteStatusKeys, key)
}

// Skip updating status for policies with empty status
// They may have been skipped in this translation because
// their target is not found (not relevant)

for _, backendTLSPolicy := range result.BackendTLSPolicies {
backendTLSPolicy := backendTLSPolicy
key := utils.NamespacedName(backendTLSPolicy)
r.ProviderResources.BackendTLSPolicyStatuses.Store(key, &backendTLSPolicy.Status)
if !(reflect.ValueOf(backendTLSPolicy.Status).IsZero()) {
r.ProviderResources.BackendTLSPolicyStatuses.Store(key, &backendTLSPolicy.Status)
}
delete(statusesToDelete.BackendTLSPolicyStatusKeys, key)
}

for _, clientTrafficPolicy := range result.ClientTrafficPolicies {
clientTrafficPolicy := clientTrafficPolicy
key := utils.NamespacedName(clientTrafficPolicy)
r.ProviderResources.ClientTrafficPolicyStatuses.Store(key, &clientTrafficPolicy.Status)
if !(reflect.ValueOf(clientTrafficPolicy.Status).IsZero()) {
r.ProviderResources.ClientTrafficPolicyStatuses.Store(key, &clientTrafficPolicy.Status)
}
delete(statusesToDelete.ClientTrafficPolicyStatusKeys, key)
}
for _, backendTrafficPolicy := range result.BackendTrafficPolicies {
backendTrafficPolicy := backendTrafficPolicy
key := utils.NamespacedName(backendTrafficPolicy)
r.ProviderResources.BackendTrafficPolicyStatuses.Store(key, &backendTrafficPolicy.Status)
if !(reflect.ValueOf(backendTrafficPolicy.Status).IsZero()) {
r.ProviderResources.BackendTrafficPolicyStatuses.Store(key, &backendTrafficPolicy.Status)
}
delete(statusesToDelete.BackendTrafficPolicyStatusKeys, key)
}
for _, securityPolicy := range result.SecurityPolicies {
securityPolicy := securityPolicy
key := utils.NamespacedName(securityPolicy)
r.ProviderResources.SecurityPolicyStatuses.Store(key, &securityPolicy.Status)
if !(reflect.ValueOf(securityPolicy.Status).IsZero()) {
r.ProviderResources.SecurityPolicyStatuses.Store(key, &securityPolicy.Status)
}
delete(statusesToDelete.SecurityPolicyStatusKeys, key)
}
}
Expand Down
10 changes: 6 additions & 4 deletions internal/provider/kubernetes/controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -822,8 +822,9 @@ func (r *gatewayAPIReconciler) processBackendTrafficPolicies(ctx context.Context

for _, policy := range backendTrafficPolicies.Items {
policy := policy
// The status of BackendTrafficPolicies can't be discarded because the status
// can be modified by multiple controllers.
// Discard Status to reduce memory consumption in watchable
// It will be recomputed by the gateway-api layer
policy.Status = gwapiv1a2.PolicyStatus{}
resourceTree.BackendTrafficPolicies = append(resourceTree.BackendTrafficPolicies, &policy)
}
return nil
Expand Down Expand Up @@ -863,8 +864,9 @@ func (r *gatewayAPIReconciler) processBackendTLSPolicies(

for _, policy := range backendTLSPolicies.Items {
policy := policy
// The status of BackendTLSPolicies can't be discarded because the status
// can be modified by multiple controllers.
// Discard Status to reduce memory consumption in watchable
// It will be recomputed by the gateway-api layer
policy.Status = gwapiv1a2.PolicyStatus{}
resourceTree.BackendTLSPolicies = append(resourceTree.BackendTLSPolicies, &policy)
}

Expand Down
8 changes: 7 additions & 1 deletion internal/xds/translator/runner/runner.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ package runner

import (
"context"
"reflect"

ktypes "k8s.io/apimachinery/pkg/types"

Expand Down Expand Up @@ -104,7 +105,12 @@ func (r *Runner) subscribeAndTranslate(ctx context.Context) {
Name: e.Name,
Namespace: e.Namespace,
}
r.ProviderResources.EnvoyPatchPolicyStatuses.Store(key, e.Status)
// Skip updating status for policies with empty status
// They may have been skipped in this translation because
// their target is not found (not relevant)
if !(reflect.ValueOf(e.Status).IsZero()) {
r.ProviderResources.EnvoyPatchPolicyStatuses.Store(key, e.Status)
}
delete(statusesToDelete, key)
}
// Discard the EnvoyPatchPolicyStatuses to reduce memory footprint
Expand Down

0 comments on commit 45f52e8

Please sign in to comment.