Skip to content

Commit 0823530

Browse files
authored
Merge pull request #3031 from k8s-infra-cherrypick-robot/cherry-pick-3028-to-release-0.19
[release-0.19] 🐛 Use leader elector with client timeout
2 parents e727239 + 2a0ce59 commit 0823530

File tree

3 files changed

+46
-2
lines changed

3 files changed

+46
-2
lines changed

pkg/leaderelection/leader_election.go

+23-2
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,7 @@ import (
2020
"errors"
2121
"fmt"
2222
"os"
23+
"time"
2324

2425
"k8s.io/apimachinery/pkg/util/uuid"
2526
coordinationv1client "k8s.io/client-go/kubernetes/typed/coordination/v1"
@@ -49,6 +50,12 @@ type Options struct {
4950
// LeaderElectionID determines the name of the resource that leader election
5051
// will use for holding the leader lock.
5152
LeaderElectionID string
53+
54+
// RenewDeadline is the renew deadline for this leader election client.
55+
// Must be set to ensure the resource lock has an appropriate client timeout.
56+
// Without that, a single slow response from the API server can result
57+
// in losing leadership.
58+
RenewDeadline time.Duration
5259
}
5360

5461
// NewResourceLock creates a new resource lock for use in a leader election loop.
@@ -88,6 +95,20 @@ func NewResourceLock(config *rest.Config, recorderProvider recorder.Provider, op
8895

8996
// Construct clients for leader election
9097
rest.AddUserAgent(config, "leader-election")
98+
99+
if options.RenewDeadline != 0 {
100+
return resourcelock.NewFromKubeconfig(options.LeaderElectionResourceLock,
101+
options.LeaderElectionNamespace,
102+
options.LeaderElectionID,
103+
resourcelock.ResourceLockConfig{
104+
Identity: id,
105+
EventRecorder: recorderProvider.GetEventRecorderFor(id),
106+
},
107+
config,
108+
options.RenewDeadline,
109+
)
110+
}
111+
91112
corev1Client, err := corev1client.NewForConfig(config)
92113
if err != nil {
93114
return nil, err
@@ -97,7 +118,6 @@ func NewResourceLock(config *rest.Config, recorderProvider recorder.Provider, op
97118
if err != nil {
98119
return nil, err
99120
}
100-
101121
return resourcelock.New(options.LeaderElectionResourceLock,
102122
options.LeaderElectionNamespace,
103123
options.LeaderElectionID,
@@ -106,7 +126,8 @@ func NewResourceLock(config *rest.Config, recorderProvider recorder.Provider, op
106126
resourcelock.ResourceLockConfig{
107127
Identity: id,
108128
EventRecorder: recorderProvider.GetEventRecorderFor(id),
109-
})
129+
},
130+
)
110131
}
111132

112133
func getInClusterNamespace() (string, error) {

pkg/manager/manager.go

+1
Original file line numberDiff line numberDiff line change
@@ -389,6 +389,7 @@ func New(config *rest.Config, options Options) (Manager, error) {
389389
LeaderElectionResourceLock: options.LeaderElectionResourceLock,
390390
LeaderElectionID: options.LeaderElectionID,
391391
LeaderElectionNamespace: options.LeaderElectionNamespace,
392+
RenewDeadline: *options.RenewDeadline,
392393
})
393394
if err != nil {
394395
return nil, err

pkg/manager/manager_test.go

+22
Original file line numberDiff line numberDiff line change
@@ -317,6 +317,28 @@ var _ = Describe("manger.Manager", func() {
317317
<-m2done
318318
})
319319

320+
It("should default RenewDeadline for leader election config", func() {
321+
var rl resourcelock.Interface
322+
m1, err := New(cfg, Options{
323+
LeaderElection: true,
324+
LeaderElectionNamespace: "default",
325+
LeaderElectionID: "test-leader-election-id",
326+
newResourceLock: func(config *rest.Config, recorderProvider recorder.Provider, options leaderelection.Options) (resourcelock.Interface, error) {
327+
if options.RenewDeadline != 10*time.Second {
328+
return nil, fmt.Errorf("expected RenewDeadline to be 10s, got %v", options.RenewDeadline)
329+
}
330+
var err error
331+
rl, err = leaderelection.NewResourceLock(config, recorderProvider, options)
332+
return rl, err
333+
},
334+
HealthProbeBindAddress: "0",
335+
Metrics: metricsserver.Options{BindAddress: "0"},
336+
PprofBindAddress: "0",
337+
})
338+
Expect(err).ToNot(HaveOccurred())
339+
Expect(m1).ToNot(BeNil())
340+
})
341+
320342
It("should default ID to controller-runtime if ID is not set", func() {
321343
var rl resourcelock.Interface
322344
m1, err := New(cfg, Options{

0 commit comments

Comments
 (0)