Don't read cache entry twice with exclusive access

This commit is contained in:
Unrud 2017-08-01 17:16:58 +02:00
parent 1576f9b7fb
commit ed3708db22

View File

@ -1299,15 +1299,13 @@ class Collection(BaseCollection):
href) href)
vobject_item = None vobject_item = None
if input_hash != cache_hash: if input_hash != cache_hash:
# Lock the item cache to prevent multpile processes from generating with contextlib.ExitStack() as lock_stack:
# the same data in parallel. This is only needed for performance. # Lock the item cache to prevent multpile processes from
if self._lock.locked() == "w": # generating the same data in parallel.
# The access is already exclusive, use dummy context manager. # This improves the performance for multiple requests.
lock = contextlib.suppress() if self._lock.locked() == "r":
else: lock_stack.enter_context(self._acquire_cache_lock("item"))
lock = self._acquire_cache_lock("item") # Check if another process created the file in the meantime
with lock:
# Check if another process created the file in the meantime.
cache_hash, uid, etag, text, tag, start, end = \ cache_hash, uid, etag, text, tag, start, end = \
self._load_item_cache(href) self._load_item_cache(href)
if input_hash != cache_hash: if input_hash != cache_hash: