aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2021-01-07 11:45:09 -0500
committerTom Lane <tgl@sss.pgh.pa.us>2021-01-07 11:45:09 -0500
commit5db4fdc22472919f97ce83d276fb34b47c794d1f (patch)
treea5a7f9b1f7b6a3d7bdbcda1345f46d94ad1b5434
parent0f8977b3f2536c91a0a97e2395c297d3acf1f491 (diff)
downloadpostgresql-5db4fdc22472919f97ce83d276fb34b47c794d1f.tar.gz
postgresql-5db4fdc22472919f97ce83d276fb34b47c794d1f.zip
Further second thoughts about idle_session_timeout patch.
On reflection, the order of operations in PostgresMain() is wrong. These timeouts ought to be shut down before, not after, we do the post-command-read CHECK_FOR_INTERRUPTS, to guarantee that any timeout error will be detected there rather than at some ill-defined later point (possibly after having wasted a lot of work). This is really an error in the original idle_in_transaction_timeout patch, so back-patch to 9.6 where that was introduced.
-rw-r--r--src/backend/tcop/postgres.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/src/backend/tcop/postgres.c b/src/backend/tcop/postgres.c
index 899723470d6..174c72a14bc 100644
--- a/src/backend/tcop/postgres.c
+++ b/src/backend/tcop/postgres.c
@@ -4269,7 +4269,18 @@ PostgresMain(int argc, char *argv[],
firstchar = ReadCommand(&input_message);
/*
- * (4) disable async signal conditions again.
+ * (4) turn off the idle-in-transaction timeout, if active. We do
+ * this before step (5) so that any last-moment timeout is certain to
+ * be detected in step (5).
+ */
+ if (disable_idle_in_transaction_timeout)
+ {
+ disable_timeout(IDLE_IN_TRANSACTION_SESSION_TIMEOUT, false);
+ disable_idle_in_transaction_timeout = false;
+ }
+
+ /*
+ * (5) disable async signal conditions again.
*
* Query cancel is supposed to be a no-op when there is no query in
* progress, so if a query cancel arrived while we were idle, just
@@ -4281,15 +4292,6 @@ PostgresMain(int argc, char *argv[],
DoingCommandRead = false;
/*
- * (5) turn off the idle-in-transaction timeout
- */
- if (disable_idle_in_transaction_timeout)
- {
- disable_timeout(IDLE_IN_TRANSACTION_SESSION_TIMEOUT, false);
- disable_idle_in_transaction_timeout = false;
- }
-
- /*
* (6) check for any other interesting events that happened while we
* slept.
*/