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:
parent
2b9fa41a6e
commit
618fb5b34d
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue