From 9ad18061bd02830aa518b191425d1ea5f91ebb9a Mon Sep 17 00:00:00 2001 From: Alessandro Molina Date: Tue, 9 Apr 2024 21:48:08 +0200 Subject: [PATCH] Redis cluster lock (#238) --- beaker/ext/redisclusternm.py | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/beaker/ext/redisclusternm.py b/beaker/ext/redisclusternm.py index 0024ae8..96a43d5 100644 --- a/beaker/ext/redisclusternm.py +++ b/beaker/ext/redisclusternm.py @@ -75,6 +75,13 @@ class RedisClusterSynchronizer(RedisSynchronizer): This Synchronizer only supports 1 reader or 1 writer at time, not concurrent readers. """ + RELEASE_LOCK_LUA = """ + if redis.call('get', KEYS[1]) == ARGV[1] then + return redis.call('del', KEYS[1]) + else + return 0 + end + """ def __init__(self, identifier, urls, nodes=None, **kwargs): super(RedisSynchronizer, self).__init__() @@ -85,3 +92,9 @@ def __init__(self, identifier, urls, nodes=None, **kwargs): ) else: self.client = urls + self._release_lock = self.client.register_script(self.RELEASE_LOCK_LUA) + + def do_release_write_lock(self): + identifier = self.identifier + owner_id = self._get_owner_id() + self._release_lock(keys=[identifier], args=[owner_id]) \ No newline at end of file