Skip to content

Commit

Permalink
protect cron jobs from database outages/migrations
Browse files Browse the repository at this point in the history
fixes LIBERAPAYCOM-24T
  • Loading branch information
Changaco committed Apr 9, 2024
1 parent 4edcdfe commit e46f711
Showing 1 changed file with 31 additions and 18 deletions.
49 changes: 31 additions & 18 deletions liberapay/cron.py
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down

0 comments on commit e46f711

Please sign in to comment.