From 2458b78fc69aedf9537bda1e5b4d9006dadf0bc0 Mon Sep 17 00:00:00 2001 From: Ashish Tiwari Date: Mon, 14 Oct 2024 21:26:29 +0530 Subject: [PATCH] fix: candidate controllers missing Forget call in workqueue (#2308) --- pkg/providers/apisix/apisix_global_rule.go | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/pkg/providers/apisix/apisix_global_rule.go b/pkg/providers/apisix/apisix_global_rule.go index 69b3d11fdd..4948543d4f 100644 --- a/pkg/providers/apisix/apisix_global_rule.go +++ b/pkg/providers/apisix/apisix_global_rule.go @@ -179,6 +179,13 @@ func (c *apisixGlobalRuleController) sync(ctx context.Context, ev *types.Event) } func (c *apisixGlobalRuleController) handleSyncErr(obj interface{}, errOrigin error) { + if errOrigin == nil { + c.MetricsCollector.IncrSyncOperation("GlobalRule", "success") + c.workqueue.Forget(obj) + } else { + c.workqueue.AddRateLimited(obj) + c.MetricsCollector.IncrSyncOperation("GlobalRule", "failure") + } ev := obj.(*types.Event) event := ev.Object.(kube.ApisixGlobalRuleEvent) if k8serrors.IsNotFound(errOrigin) && ev.Type != types.EventDelete { @@ -219,8 +226,6 @@ func (c *apisixGlobalRuleController) handleSyncErr(obj interface{}, errOrigin er ) } } - c.workqueue.Forget(obj) - c.MetricsCollector.IncrSyncOperation("GlobalRule", "success") return } log.Warnw("sync ApisixGlobalRule failed, will retry", @@ -241,8 +246,6 @@ func (c *apisixGlobalRuleController) handleSyncErr(obj interface{}, errOrigin er ) } } - c.workqueue.AddRateLimited(obj) - c.MetricsCollector.IncrSyncOperation("GlobalRule", "failure") } func (c *apisixGlobalRuleController) onAdd(obj interface{}) {