gitlab-org--gitlab-foss/lib/gitlab/exclusive_lease_helpers.rb

34 lines
1.1 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2018-07-03 03:20:27 -04:00
module Gitlab
# This module provides helper methods which are intregrated with GitLab::ExclusiveLease
module ExclusiveLeaseHelpers
FailedToObtainLockError = Class.new(StandardError)
##
# This helper method blocks a process/thread until the other process cancel the obrainted lease key.
#
# Note: It's basically discouraged to use this method in the unicorn's thread,
# because it holds the connection until all `retries` is consumed.
# This could potentially eat up all connection pools.
def in_lock(key, ttl: 1.minute, retries: 10, sleep_sec: 0.01.seconds)
2018-11-23 11:25:11 -05:00
raise ArgumentError, 'Key needs to be specified' unless key
2018-07-03 03:20:27 -04:00
lease = Gitlab::ExclusiveLease.new(key, timeout: ttl)
until uuid = lease.try_obtain
# Keep trying until we obtain the lease. To prevent hammering Redis too
# much we'll wait for a bit.
sleep(sleep_sec)
break if (retries -= 1) < 0
end
raise FailedToObtainLockError, 'Failed to obtain a lock' unless uuid
2018-07-09 05:13:11 -04:00
yield
2018-07-03 03:20:27 -04:00
ensure
Gitlab::ExclusiveLease.cancel(key, uuid)
end
end
end