From e6aab8948af8fbf65d74d448484cad5f61b7e646 Mon Sep 17 00:00:00 2001 From: changzhen Date: Sat, 13 Jul 2024 15:05:28 +0800 Subject: [PATCH] Fix the issue of residual work in the MultiClusterService feature. Signed-off-by: changzhen --- .../endpointslice_collect_controller.go | 8 ++++++-- .../endpointslice_dispatch_controller.go | 10 +--------- pkg/util/helper/work.go | 1 + 3 files changed, 8 insertions(+), 11 deletions(-) diff --git a/pkg/controllers/multiclusterservice/endpointslice_collect_controller.go b/pkg/controllers/multiclusterservice/endpointslice_collect_controller.go index 08cd0292b4f6..a13a6c7f3ed9 100644 --- a/pkg/controllers/multiclusterservice/endpointslice_collect_controller.go +++ b/pkg/controllers/multiclusterservice/endpointslice_collect_controller.go @@ -421,8 +421,12 @@ func getEndpointSliceWorkMeta(c client.Client, ns string, workName string, endpo controllerSet.Insert(util.MultiClusterServiceKind) labels[util.EndpointSliceWorkManagedByLabel] = strings.Join(controllerSet.UnsortedList(), ".") } - workMeta := metav1.ObjectMeta{Name: workName, Namespace: ns, Labels: labels} - return workMeta, nil + return metav1.ObjectMeta{ + Name: workName, + Namespace: ns, + Labels: labels, + Finalizers: []string{util.MCSEndpointSliceDispatchControllerFinalizer}, + }, nil } func cleanupWorkWithEndpointSliceDelete(c client.Client, endpointSliceKey keys.FederatedKey) error { diff --git a/pkg/controllers/multiclusterservice/endpointslice_dispatch_controller.go b/pkg/controllers/multiclusterservice/endpointslice_dispatch_controller.go index 8175a65ef43f..0eb5727dbc65 100644 --- a/pkg/controllers/multiclusterservice/endpointslice_dispatch_controller.go +++ b/pkg/controllers/multiclusterservice/endpointslice_dispatch_controller.go @@ -308,7 +308,7 @@ func (c *EndpointsliceDispatchController) cleanOrphanDispatchedEndpointSlice(ctx return nil } -func (c *EndpointsliceDispatchController) dispatchEndpointSlice(ctx context.Context, work *workv1alpha1.Work, mcs *networkingv1alpha1.MultiClusterService) error { +func (c *EndpointsliceDispatchController) dispatchEndpointSlice(_ context.Context, work *workv1alpha1.Work, mcs *networkingv1alpha1.MultiClusterService) error { epsSourceCluster, err := names.GetClusterName(work.Namespace) if err != nil { klog.Errorf("Failed to get EndpointSlice source cluster name for work %s/%s", work.Namespace, work.Name) @@ -347,14 +347,6 @@ func (c *EndpointsliceDispatchController) dispatchEndpointSlice(ctx context.Cont return err } } - - if controllerutil.AddFinalizer(work, util.MCSEndpointSliceDispatchControllerFinalizer) { - if err := c.Client.Update(ctx, work); err != nil { - klog.Errorf("Failed to add finalizer %s for work %s/%s:%v", util.MCSEndpointSliceDispatchControllerFinalizer, work.Namespace, work.Name, err) - return err - } - } - return nil } diff --git a/pkg/util/helper/work.go b/pkg/util/helper/work.go index 0db7819ffe6f..f256a40d7a23 100644 --- a/pkg/util/helper/work.go +++ b/pkg/util/helper/work.go @@ -84,6 +84,7 @@ func CreateOrUpdateWork(client client.Client, workMeta metav1.ObjectMeta, resour runtimeObject.Spec = work.Spec runtimeObject.Labels = util.DedupeAndMergeLabels(runtimeObject.Labels, work.Labels) runtimeObject.Annotations = util.DedupeAndMergeAnnotations(runtimeObject.Annotations, work.Annotations) + runtimeObject.Finalizers = work.Finalizers return nil }) return err