pgsql: postgres_fdw: Restructure connection retry logic.

From: Fujii Masao <fujii(at)postgresql(dot)org>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: postgres_fdw: Restructure connection retry logic.
Date: 2020-10-16 05:00:11
Message-ID: E1kTHqd-0006zm-PU@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

postgres_fdw: Restructure connection retry logic.

Commit 32a9c0bdf introduced connection retry logic into postgres_fdw.
Previously it used goto statement for retry. This commit gets rid of that
goto from the logic to make the code simpler and easier-to-read.

When getting out of PG_CATCH() for the retry, the error state should be
cleaned up and the memory context should be reset. But commit 32a9c0bdf
forgot to do that. This commit also fixes this bug.

Previously only PQstatus()==CONNECTION_BAD was verified to detect
connection failure. But this could cause false detection in the case where
any error other than connection failure (e.g., out-of-memory) was thrown
after a broken connection was detected in libpq and CONNECTION_BAD is set.
To fix this issue, this commit changes the logic so that it also checks
the error's sqlstate is ERRCODE_CONNECTION_FAILURE.

Author: Fujii Masao
Reviewed-by: Tom Lane
Discussion: https://postgr.es/m/2943611.1602375376@sss.pgh.pa.us

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/7fc1a81e4982b6722405b032e21be38dbbef5b80

Modified Files
--------------
contrib/postgres_fdw/connection.c | 136 +++++++++++++++++++++++++-------------
1 file changed, 90 insertions(+), 46 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Fujii Masao 2020-10-16 05:01:22 Re: pgsql: postgres_fdw: reestablish new connection if cached one is detect
Previous Message Andres Freund 2020-10-16 01:24:47 pgsql: llvmjit: Work around bug in LLVM 3.9 causing crashes after 72559