Skip to content

Commit

Permalink
use sync.Once to initialize webhook server
Browse files Browse the repository at this point in the history
Signed-off-by: Eric Stroczynski <[email protected]>
  • Loading branch information
estroz authored and Ayush Rangwala committed May 5, 2021
1 parent 4b22c1a commit 45bbfa1
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 41 deletions.
36 changes: 13 additions & 23 deletions pkg/manager/internal.go
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,9 @@ type controllerManager struct {
certDir string

webhookServer *webhook.Server
// webhookServerOnce will be called in GetWebhookServer() to optionally initialize
// webhookServer if unset, and Add() it to controllerManager.
webhookServerOnce sync.Once

// leaseDuration is the duration that non-leader candidates will
// wait to force acquire leadership.
Expand Down Expand Up @@ -332,32 +335,19 @@ func (cm *controllerManager) GetAPIReader() client.Reader {
}

func (cm *controllerManager) GetWebhookServer() *webhook.Server {
server, wasNew := func() (*webhook.Server, bool) {
cm.mu.Lock()
defer cm.mu.Unlock()

if cm.webhookServer != nil {
return cm.webhookServer, false
}

cm.webhookServer = &webhook.Server{
Port: cm.port,
Host: cm.host,
CertDir: cm.certDir,
cm.webhookServerOnce.Do(func() {
if cm.webhookServer == nil {
cm.webhookServer = &webhook.Server{
Port: cm.port,
Host: cm.host,
CertDir: cm.certDir,
}
}
return cm.webhookServer, true
}()

// only add the server if *we ourselves* just registered it.
// Add has its own lock, so just do this separately -- there shouldn't
// be a "race" in this lock gap because the condition is the population
// of cm.webhookServer, not anything to do with Add.
if wasNew {
if err := cm.Add(server); err != nil {
if err := cm.Add(cm.webhookServer); err != nil {
panic("unable to add webhook server to the controller manager")
}
}
return server
})
return cm.webhookServer
}

func (cm *controllerManager) GetLogger() logr.Logger {
Expand Down
14 changes: 2 additions & 12 deletions pkg/manager/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -365,7 +365,7 @@ func New(config *rest.Config, options Options) (Manager, error) {
return nil, err
}

cm := &controllerManager{
return &controllerManager{
cluster: cluster,
recorderProvider: recorderProvider,
resourceLock: resourceLock,
Expand All @@ -387,17 +387,7 @@ func New(config *rest.Config, options Options) (Manager, error) {
gracefulShutdownTimeout: *options.GracefulShutdownTimeout,
internalProceduresStop: make(chan struct{}),
leaderElectionStopped: make(chan struct{}),
}

// A webhook server set by New's caller should be added now
// so GetWebhookServer can construct a new one if unset and add it only once.
if cm.webhookServer != nil {
if err := cm.Add(cm.webhookServer); err != nil {
return nil, err
}
}

return cm, nil
}, nil
}

// AndFrom will use a supplied type and convert to Options
Expand Down
6 changes: 0 additions & 6 deletions pkg/manager/manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -280,12 +280,6 @@ var _ = Describe("manger.Manager", func() {
Expect(err).NotTo(HaveOccurred())
Expect(m).NotTo(BeNil())

By("checking the webhook server was added to non-leader-election runnables")
Expect(m).To(BeAssignableToTypeOf(&controllerManager{}))
nonLERunnables := m.(*controllerManager).nonLeaderElectionRunnables
Expect(nonLERunnables).To(HaveLen(1))
Expect(nonLERunnables[0]).To(BeAssignableToTypeOf(&webhook.Server{}))

By("checking the server contains the Port set on the webhook server and not passed to Options")
svr := m.GetWebhookServer()
Expect(svr).NotTo(BeNil())
Expand Down

0 comments on commit 45bbfa1

Please sign in to comment.