1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2025-01-20 14:29:25 +00:00

locking: ignore+delete locks of dead processes

This commit is contained in:
Thomas Waldmann 2024-08-31 04:13:04 +02:00
parent 86dc673649
commit dc9fff9953
No known key found for this signature in database
GPG key ID: 243ACFA951F78E01

View file

@ -107,8 +107,17 @@ def _delete_lock(self, key, *, ignore_not_found=False):
if not ignore_not_found:
raise
def _get_locks(self):
def _is_stale_lock(self, lock):
now = datetime.datetime.now(datetime.timezone.utc)
if lock["dt"] < now - self.stale_td:
# lock is too old, it was not refreshed.
return True
if not platform.process_alive(lock["hostid"], lock["processid"], lock["threadid"]):
# we KNOW that the lock owning process is dead.
return True
return False
def _get_locks(self):
locks = {}
try:
infos = list(self.store.list("locks"))
@ -118,14 +127,12 @@ def _get_locks(self):
key = info.name
content = self.store.load(f"locks/{key}")
lock = json.loads(content.decode("utf-8"))
dt = datetime.datetime.fromisoformat(lock["time"])
stale = dt < now - self.stale_td
if stale:
lock["key"] = key
lock["dt"] = datetime.datetime.fromisoformat(lock["time"])
if self._is_stale_lock(lock):
# ignore it and delete it (even if it is not from us)
self._delete_lock(key, ignore_not_found=True)
else:
lock["key"] = key
lock["dt"] = dt
locks[key] = lock
return locks