Merge pull request #1908 from leonelcamara/make_sure_to_unlock_redis
Release the lock even if function call fails
This commit is contained in:
@@ -159,13 +159,15 @@ class RedisClient(object):
|
||||
lock_key = '%s:__lock' % newKey
|
||||
randomvalue = time.time()
|
||||
al = acquire_lock(self.r_server, lock_key, randomvalue)
|
||||
# someone may have computed it
|
||||
obj = self.r_server.get(newKey)
|
||||
if obj is None:
|
||||
value = self.cache_it(newKey, f, time_expire)
|
||||
else:
|
||||
value = pickle.loads(obj)
|
||||
release_lock(self, lock_key, al)
|
||||
try:
|
||||
# someone may have computed it
|
||||
obj = self.r_server.get(newKey)
|
||||
if obj is None:
|
||||
value = self.cache_it(newKey, f, time_expire)
|
||||
else:
|
||||
value = pickle.loads(obj)
|
||||
finally:
|
||||
release_lock(self, lock_key, al)
|
||||
else:
|
||||
# without distributed locking
|
||||
value = self.cache_it(newKey, f, time_expire)
|
||||
|
||||
Reference in New Issue
Block a user