remove the startup jitter before locks() (#16340)

This commit is contained in:
Harshavardhana 2023-01-02 01:40:09 -08:00 committed by GitHub
parent 62cd918061
commit 1cd8e1d8b6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -377,10 +377,6 @@ func initServer(ctx context.Context, newObject ObjectLayer) error {
minimum: 3 * time.Second, minimum: 3 * time.Second,
}) })
// Do an initial random sleep to avoid stampeding herd of initial
// lock request. This will spread locks requests over 1 second.
time.Sleep(time.Duration(r.Float64() * float64(time.Second)))
for { for {
select { select {
case <-ctx.Done(): case <-ctx.Done():
@ -403,10 +399,11 @@ func initServer(ctx context.Context, newObject ObjectLayer) error {
lkctx, err := txnLk.GetLock(ctx, lockTimeout) lkctx, err := txnLk.GetLock(ctx, lockTimeout)
if err != nil { if err != nil {
logger.Info("Waiting for all MinIO sub-systems to be initialized.. trying to acquire lock") logger.Info("Waiting for all MinIO sub-systems to be initialized.. trying to acquire lock")
bootstrapTrace(fmt.Sprintf("lock not available. error: %v. sleeping before retry", err)) waitDuration := time.Duration(r.Float64() * 2 * float64(time.Second))
bootstrapTrace(fmt.Sprintf("lock not available. error: %v. sleeping for %v before retry", err, waitDuration))
// Sleep 0 -> 2 seconds to average 1 second retry interval. // Sleep 0 -> 2 seconds to average 1 second retry interval.
time.Sleep(time.Duration(r.Float64() * 2 * float64(time.Second))) time.Sleep(waitDuration)
continue continue
} }