mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 22:06:20 +00:00
agent/consul: change provider wait from goto to a loop
This commit is contained in:
parent
c8b65217c3
commit
bc605a1576
@ -489,19 +489,22 @@ func (s *Server) createCAProvider(conf *structs.CAConfiguration) (connect.CAProv
|
||||
|
||||
func (s *Server) getCAProvider() connect.CAProvider {
|
||||
retries := 0
|
||||
var result connect.CAProvider
|
||||
for result == nil {
|
||||
s.caProviderLock.RLock()
|
||||
result = s.caProvider
|
||||
s.caProviderLock.RUnlock()
|
||||
|
||||
RETRY_PROVIDER:
|
||||
s.caProviderLock.RLock()
|
||||
result := s.caProvider
|
||||
s.caProviderLock.RUnlock()
|
||||
// In cases where an agent is started with managed proxies, we may ask
|
||||
// for the provider before establishLeadership completes. If we're the
|
||||
// leader, then wait and get the provider again
|
||||
if result == nil && s.IsLeader() && retries < 10 {
|
||||
retries++
|
||||
time.Sleep(50 * time.Millisecond)
|
||||
continue
|
||||
}
|
||||
|
||||
// In cases where an agent is started with managed proxies, we may ask
|
||||
// for the provider before establishLeadership completes. If we're the
|
||||
// leader, then wait and get the provider again
|
||||
if result == nil && s.IsLeader() && retries < 10 {
|
||||
retries++
|
||||
time.Sleep(50 * time.Millisecond)
|
||||
goto RETRY_PROVIDER
|
||||
break
|
||||
}
|
||||
|
||||
return result
|
||||
|
Loading…
x
Reference in New Issue
Block a user