Skip to content

Commit

Permalink
feat: remove leader election for operator (#1000)
Browse files Browse the repository at this point in the history
- since our design is for only one instance of pod, there is no need to enable
leader-election
- in a shady env. this can cause error

Signed-off-by: Wen Zhou <wenzhou@redhat.com>
  • Loading branch information
zdtsw committed May 9, 2024
1 parent 4f3ad07 commit cc2f03c
Show file tree
Hide file tree
Showing 6 changed files with 2 additions and 48 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -9,19 +9,6 @@ data:
bindAddress: 0.0.0.0:8080
webhook:
port: 9443
leaderElection:
leaderElect: true
resourceName: 07ed84f7.opendatahub.io
# leaderElectionReleaseOnCancel defines if the leader should step down volume
# when the Manager ends. This requires the binary to immediately end when the
# Manager is stopped, otherwise, this setting is unsafe. Setting this significantly
# speeds up voluntary leader transitions as the new leader don't have to wait
# LeaseDuration time first.
# In the default scaffold provided, the program ends immediately after
# the manager stops, so would be fine to enable this option. However,
# if you are doing or is intended to do any operation such as perform cleanups
# after the manager stops then its usage might be unsafe.
# leaderElectionReleaseOnCancel: true
kind: ConfigMap
metadata:
name: redhat-ods-operator-manager-config
1 change: 0 additions & 1 deletion bundle/manifests/rhods-operator.clusterserviceversion.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -1672,7 +1672,6 @@ spec:
- args:
- --health-probe-bind-address=:8081
- --metrics-bind-address=0.0.0.0:8080
- --leader-elect
command:
- /manager
image: REPLACE_IMAGE:latest
Expand Down
1 change: 0 additions & 1 deletion config/default/manager_auth_proxy_patch.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,3 @@ spec:
args:
- "--health-probe-bind-address=:8081"
- "--metrics-bind-address=0.0.0.0:8080"
- "--leader-elect"
13 changes: 0 additions & 13 deletions config/manager/controller_manager_config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,3 @@ metrics:
bindAddress: 0.0.0.0:8080
webhook:
port: 9443
leaderElection:
leaderElect: true
resourceName: 07ed84f7.opendatahub.io
# leaderElectionReleaseOnCancel defines if the leader should step down volume
# when the Manager ends. This requires the binary to immediately end when the
# Manager is stopped, otherwise, this setting is unsafe. Setting this significantly
# speeds up voluntary leader transitions as the new leader don't have to wait
# LeaseDuration time first.
# In the default scaffold provided, the program ends immediately after
# the manager stops, so would be fine to enable this option. However,
# if you are doing or is intended to do any operation such as perform cleanups
# after the manager stops then its usage might be unsafe.
# leaderElectionReleaseOnCancel: true
1 change: 0 additions & 1 deletion config/manager/manager.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,6 @@ spec:
- command:
- /manager
args:
- --leader-elect
- --operator-name=opendatahub
image: controller:latest
imagePullPolicy: Always
Expand Down
21 changes: 2 additions & 19 deletions main.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,6 @@ func init() { //nolint:gochecknoinits

func main() {
var metricsAddr string
var enableLeaderElection bool
var probeAddr string
var dscApplicationsNamespace string
var dscMonitoringNamespace string
Expand All @@ -103,10 +102,7 @@ func main() {

flag.StringVar(&metricsAddr, "metrics-bind-address", ":8080", "The address the metric endpoint binds to.")
flag.StringVar(&probeAddr, "health-probe-bind-address", ":8081", "The address the probe endpoint binds to.")
flag.BoolVar(&enableLeaderElection, "leader-elect", false,
"Enable leader election for controller manager. "+
"Enabling this will ensure there is only one active controller manager.")
flag.StringVar(&dscApplicationsNamespace, "dsc-applications-namespace", "redhat-ods-applications", "The namespace where data science cluster"+
flag.StringVar(&dscApplicationsNamespace, "dsc-applications-namespace", "opendatahub", "The namespace where data science cluster"+
"applications will be deployed")
flag.StringVar(&dscMonitoringNamespace, "dsc-monitoring-namespace", "redhat-ods-monitoring", "The namespace where data science cluster"+
"monitoring stack will be deployed")
Expand All @@ -117,24 +113,11 @@ func main() {

ctrl.SetLogger(common.ConfigLoggers(logmode))

mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{
mgr, err := ctrl.NewManager(ctrl.GetConfigOrDie(), ctrl.Options{ // single pod does not need to have LeaderElection
Scheme: scheme,
MetricsBindAddress: metricsAddr,
Port: 9443,
HealthProbeBindAddress: probeAddr,
LeaderElection: enableLeaderElection,
LeaderElectionID: "07ed84f7.opendatahub.io",
// LeaderElectionReleaseOnCancel defines if the leader should step down voluntarily
// when the Manager ends. This requires the binary to immediately end when the
// Manager is stopped, otherwise, this setting is unsafe. Setting this significantly
// speeds up voluntary leader transitions as the new leader don't have to wait
// LeaseDuration time first.
//
// In the default scaffold provided, the program ends immediately after
// the manager stops, so would be fine to enable this option. However,
// if you are doing or is intended to do any operation such as perform cleanups
// after the manager stops then its usage might be unsafe.
// LeaderElectionReleaseOnCancel: true,
})
if err != nil {
setupLog.Error(err, "unable to start manager")
Expand Down

0 comments on commit cc2f03c

Please sign in to comment.