FIX: properly count DistributedMutex locking attempts

When originally introduced, `attempts` was only used in the read-only check
context.

With the introduction of the exponential backoff in cda370db, `attempts` was
also used to count loop iterations, but was left inside the if block instead of
being incremented every loop, meaning the exponential backoff was only
happening when the site was recently readonly.

Co-authored-by: jbrw <jamie.wilson@discourse.org>
This commit is contained in:
Michael Brown 2022-12-13 17:09:01 -05:00 committed by Michael Brown
parent 2b9fa41a6e
commit 618fb5b34d
1 changed files with 3 additions and 6 deletions

View File

@ -88,17 +88,14 @@ class DistributedMutex
# Exponential backoff, max duration 1s # Exponential backoff, max duration 1s
interval = attempts < 10 ? (0.001 * 2**attempts) : 1 interval = attempts < 10 ? (0.001 * 2**attempts) : 1
sleep interval sleep interval
# in readonly we will never be able to get a lock
if @using_global_redis && Discourse.recently_readonly?
attempts += 1 attempts += 1
if attempts > CHECK_READONLY_ATTEMPTS # in readonly we will never be able to get a lock
if @using_global_redis && Discourse.recently_readonly? && attempts > CHECK_READONLY_ATTEMPTS
raise Discourse::ReadOnly raise Discourse::ReadOnly
end end
end end
end end
end
def prefixed_key def prefixed_key
@prefixed_key ||= redis.respond_to?(:namespace_key) ? redis.namespace_key(key) : key @prefixed_key ||= redis.respond_to?(:namespace_key) ? redis.namespace_key(key) : key