forked from mirror/redis
24 lines
504 B
Go
24 lines
504 B
Go
|
package internal
|
||
|
|
||
|
import (
|
||
|
"math/rand"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
const retryBackoff = 8 * time.Millisecond
|
||
|
|
||
|
// Retry backoff with jitter sleep to prevent overloaded conditions during intervals
|
||
|
// https://www.awsarchitectureblog.com/2015/03/backoff.html
|
||
|
func RetryBackoff(retry int, maxRetryBackoff time.Duration) time.Duration {
|
||
|
if retry < 0 {
|
||
|
retry = 0
|
||
|
}
|
||
|
|
||
|
backoff := retryBackoff << uint(retry)
|
||
|
if backoff > maxRetryBackoff {
|
||
|
backoff = maxRetryBackoff
|
||
|
}
|
||
|
|
||
|
return time.Duration(rand.Int63n(int64(backoff)))
|
||
|
}
|