mirror of
https://github.com/grassrootseconomics/cic-custodial.git
synced 2025-01-07 07:37:31 +01:00
Mohammed Sohail
ad58d1da47
* previouly we relied on the task being re-queued which generally reduces the throughput of tasks
22 lines
434 B
Go
22 lines
434 B
Go
package task
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/bsm/redislock"
|
|
)
|
|
|
|
const (
|
|
lockPrefix = "lock:"
|
|
lockRetryDelay = 25 * time.Millisecond
|
|
)
|
|
|
|
// lockRetry will at most try to obtain the lock 20 times within ~0.5s.
|
|
// it is expected to prevent immidiate requeue of the task at the expense of more redis calls.
|
|
func lockRetry() redislock.RetryStrategy {
|
|
return redislock.LimitRetry(
|
|
redislock.LinearBackoff(lockRetryDelay),
|
|
20,
|
|
)
|
|
}
|