From 98c63ece73788bd6a5790d35b1d33e5ec4509a9c Mon Sep 17 00:00:00 2001 From: Changaco Date: Tue, 9 Apr 2024 16:49:21 +0200 Subject: [PATCH] protect cron jobs from database outages/migrations fixes LIBERAPAYCOM-24T --- liberapay/cron.py | 49 ++++++++++++++++++++++++++++++----------------- 1 file changed, 31 insertions(+), 18 deletions(-) diff --git a/liberapay/cron.py b/liberapay/cron.py index f14171e85..b6ab3b048 100644 --- a/liberapay/cron.py +++ b/liberapay/cron.py @@ -172,30 +172,43 @@ def f(): self.running = False self.cron.website.tell_sentry(e) if self.exclusive: - try: - self.cron.website.db.run(""" - INSERT INTO cron_jobs - (name, last_error_time, last_error) - VALUES (%s, current_timestamp, %s) - ON CONFLICT (name) DO UPDATE - SET last_error_time = excluded.last_error_time - , last_error = excluded.last_error - """, (func_name, traceback.format_exc())) - except psycopg2.OperationalError: - pass + while True: + try: + self.cron.website.db.run(""" + INSERT INTO cron_jobs + (name, last_error_time, last_error) + VALUES (%s, current_timestamp, %s) + ON CONFLICT (name) DO UPDATE + SET last_error_time = excluded.last_error_time + , last_error = excluded.last_error + """, (func_name, traceback.format_exc())) + except psycopg2.OperationalError as e: + self.cron.website.tell_sentry(e) + # retry in a minute + sleep(60) + else: + break # retry in a minute sleep(60) continue else: self.running = False if self.exclusive: - self.cron.website.db.run(""" - INSERT INTO cron_jobs - (name, last_success_time) - VALUES (%s, current_timestamp) - ON CONFLICT (name) DO UPDATE - SET last_success_time = excluded.last_success_time - """, (func_name,)) + while True: + try: + self.cron.website.db.run(""" + INSERT INTO cron_jobs + (name, last_success_time) + VALUES (%s, current_timestamp) + ON CONFLICT (name) DO UPDATE + SET last_success_time = excluded.last_success_time + """, (func_name,)) + except psycopg2.OperationalError: + self.cron.website.tell_sentry(e) + # retry in a minute + sleep(60) + else: + break if period == 'irregular': if r is None: return