From 422d258e1dfb1c9aa86de42ec61bba0eab715139 Mon Sep 17 00:00:00 2001 From: Seshachalam <104052572+seshachalam-yv@users.noreply.github.com> Date: Sat, 2 Sep 2023 10:06:03 +0530 Subject: [PATCH] Optimize registration logic for snapshot compaction controller (#671) Refine the approach to registering snapshot compaction controller. Instead of always running the compaction-controller and checking the CLI flag `--enable-backup-compaction` just before deploying the compaction job, the updated logic registers the compaction-controller based on the CLI flag `--enable-backup-compaction`. --- controllers/compaction/reconciler.go | 18 ++++++++---------- controllers/manager.go | 16 +++++++++------- 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/controllers/compaction/reconciler.go b/controllers/compaction/reconciler.go index d8e39c659..850ef1faa 100644 --- a/controllers/compaction/reconciler.go +++ b/controllers/compaction/reconciler.go @@ -176,17 +176,15 @@ func (r *Reconciler) reconcileJob(ctx context.Context, logger logr.Logger, etcd }, fmt.Errorf("error while fetching compaction job: %v", err) } - if r.config.EnableBackupCompaction { - // Required job doesn't exist. Create new - logger.Info("Creating etcd compaction job", "namespace", etcd.Namespace, "name", etcd.GetCompactionJobName()) - job, err = r.createCompactionJob(ctx, logger, etcd) - if err != nil { - return ctrl.Result{ - RequeueAfter: 10 * time.Second, - }, fmt.Errorf("error during compaction job creation: %v", err) - } - metricJobsCurrent.With(prometheus.Labels{druidmetrics.EtcdNamespace: etcd.Namespace}).Set(1) + // Required job doesn't exist. Create new + logger.Info("Creating etcd compaction job", "namespace", etcd.Namespace, "name", etcd.GetCompactionJobName()) + job, err = r.createCompactionJob(ctx, logger, etcd) + if err != nil { + return ctrl.Result{ + RequeueAfter: 10 * time.Second, + }, fmt.Errorf("error during compaction job creation: %v", err) } + metricJobsCurrent.With(prometheus.Labels{druidmetrics.EtcdNamespace: etcd.Namespace}).Set(1) } if !job.DeletionTimestamp.IsZero() { diff --git a/controllers/manager.go b/controllers/manager.go index 5f96f5243..07c53bef5 100644 --- a/controllers/manager.go +++ b/controllers/manager.go @@ -103,13 +103,15 @@ func registerControllersWithManager(mgr ctrl.Manager, config *ManagerConfig) err return err } - // Add compaction reconciler to the manager - compactionReconciler, err := compaction.NewReconciler(mgr, config.CompactionControllerConfig) - if err != nil { - return err - } - if err = compactionReconciler.RegisterWithManager(mgr); err != nil { - return err + // Add compaction reconciler to the manager if the CLI flag enable-backup-compaction is true. + if config.CompactionControllerConfig.EnableBackupCompaction { + compactionReconciler, err := compaction.NewReconciler(mgr, config.CompactionControllerConfig) + if err != nil { + return err + } + if err = compactionReconciler.RegisterWithManager(mgr); err != nil { + return err + } } // Add etcd-copy-backups-task reconciler to the manager