From: Sarah Hoffmann Date: Tue, 11 Feb 2020 21:00:24 +0000 (+0100) Subject: nominatim.py: also catch deadlocks on final wait X-Git-Tag: v3.5.0~83^2~2 X-Git-Url: https://git.openstreetmap.org./nominatim.git/commitdiff_plain/882f496e0a1093239a26cdbf29c9af5c5fe9977c?ds=sidebyside nominatim.py: also catch deadlocks on final wait --- diff --git a/nominatim/nominatim.py b/nominatim/nominatim.py index 848846ae..ac6d23ff 100755 --- a/nominatim/nominatim.py +++ b/nominatim/nominatim.py @@ -123,8 +123,20 @@ class DBConnection(object): def wait(self): """ Block until any pending operation is done. """ - wait_select(self.conn) - self.current_query = None + while True: + try: + wait_select(self.conn) + self.current_query = None + return + except psycopg2.extensions.TransactionRollbackError as e: + if e.pgcode == '40P01': + log.info("Deadlock detected (params = {}), retry." + .format(self.current_params)) + self.cursor.execute(self.current_query, self.current_params) + else: + raise + except psycopg2.errors.DeadlockDetected: + self.cursor.execute(self.current_query, self.current_params) def perform(self, sql, args=None): """ Send SQL query to the server. Returns immediately without @@ -158,6 +170,8 @@ class DBConnection(object): self.cursor.execute(self.current_query, self.current_params) else: raise + except psycopg2.errors.DeadlockDetected: + self.cursor.execute(self.current_query, self.current_params) return False