Retry ratchet reload on potential I/O conflicts

This commit is contained in:
Mark Qvist 2025-01-16 12:04:29 +01:00
parent 0af768e742
commit e5d446a54e

View File

@ -424,7 +424,7 @@ class Destination:
def _reload_ratchets(self, ratchets_path): def _reload_ratchets(self, ratchets_path):
if os.path.isfile(ratchets_path): if os.path.isfile(ratchets_path):
with self.ratchet_file_lock: with self.ratchet_file_lock:
try: def load_attempt():
ratchets_file = open(ratchets_path, "rb") ratchets_file = open(ratchets_path, "rb")
persisted_data = umsgpack.unpackb(ratchets_file.read()) persisted_data = umsgpack.unpackb(ratchets_file.read())
if "signature" in persisted_data and "ratchets" in persisted_data: if "signature" in persisted_data and "ratchets" in persisted_data:
@ -434,9 +434,21 @@ class Destination:
else: else:
raise KeyError("Invalid ratchet file signature") raise KeyError("Invalid ratchet file signature")
try:
try:
load_attempt()
except Exception as e:
RNS.trace_exception(e)
RNS.log(f"First ratchet reload attempt for {self} failed. Possible I/O conflict. Retrying in 500ms.", RNS.LOG_ERROR)
time.sleep(0.5)
load_attempt()
RNS.log(f"Ratchet reload retry succeeded", RNS.LOG_DEBUG)
except Exception as e: except Exception as e:
self.ratchets = None self.ratchets = None
self.ratchets_path = None self.ratchets_path = None
RNS.trace_exception(e)
raise OSError("Could not read ratchet file contents for "+str(self)+". The contained exception was: "+str(e), RNS.LOG_ERROR) raise OSError("Could not read ratchet file contents for "+str(self)+". The contained exception was: "+str(e), RNS.LOG_ERROR)
else: else:
RNS.log("No existing ratchet data found, initialising new ratchet file for "+str(self), RNS.LOG_DEBUG) RNS.log("No existing ratchet data found, initialising new ratchet file for "+str(self), RNS.LOG_DEBUG)