Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ratelimit: redis should retry if allowed requests exceeded
Implements retry on Take() for NewRedisLimiter, and now correctly logs debug message when throttling occurs. When configured to use redis, ratelimiting has always been least effort. While Take() may sleep for the requested RetryAfter time, NewRedisLimiter never re-checks to see if we're actually allowed to make further requests after the RetryAfter time expires. By re-checking Allow(), this actually enforces the desired ratelimit when multiple routines are scheduled simultaneously. This is not an issue with NewLocalLimiter since Limiter.Wait() will block until an event is allowed (or error with log.Fatal(), terminating the application). Additionally, the "throttled GitLab requests" message was never useful under its previous conditions. Both NewRedisLimiter and NewLocalLimiter are calculating `start.Sub(time.Now())` from the end of the function, which always returns a negative Duration, meaning the condition was never satisfied. Since NewLocalLimiter is already throttling correctly via Wait(), and since any non-successful return from Limiter.Wait() terminates the application via log.Fatal(); this means this "throttled" log message is likely only useful in NewRedisLimiter (when it retries).
- Loading branch information