pgsql: Rethink handling of [Prevent|Is]InTransactionBlock in pipeline m

Поиск
Список
Период
Сортировка
От Tom Lane
Тема pgsql: Rethink handling of [Prevent|Is]InTransactionBlock in pipeline m
Дата
Msg-id E1p5Asv-003R6h-6v@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Rethink handling of [Prevent|Is]InTransactionBlock in pipeline mode.

Commits f92944137 et al. made IsInTransactionBlock() set the
XACT_FLAGS_NEEDIMMEDIATECOMMIT flag before returning "false",
on the grounds that that kept its API promises equivalent to those of
PreventInTransactionBlock().  This turns out to be a bad idea though,
because it allows an ANALYZE in a pipelined series of commands to
cause an immediate commit, which is unexpected.

Furthermore, if we return "false" then we have another issue,
which is that ANALYZE will decide it's allowed to do internal
commit-and-start-transaction sequences, thus possibly unexpectedly
committing the effects of previous commands in the pipeline.

To fix the latter situation, invent another transaction state flag
XACT_FLAGS_PIPELINING, which explicitly records the fact that we
have executed some extended-protocol command and not yet seen a
commit for it.  Then, require that flag to not be set before allowing
InTransactionBlock() to return "false".

Having done that, we can remove its setting of NEEDIMMEDIATECOMMIT
without fear of causing problems.  This means that the API guarantees
of IsInTransactionBlock now diverge from PreventInTransactionBlock,
which is mildly annoying, but it seems OK given the very limited usage
of IsInTransactionBlock.  (In any case, a caller preferring the old
behavior could always set NEEDIMMEDIATECOMMIT for itself.)

For consistency also require XACT_FLAGS_PIPELINING to not be set
in PreventInTransactionBlock.  This too is meant to prevent commands
such as CREATE DATABASE from silently committing previous commands
in a pipeline.

Per report from Peter Eisentraut.  As before, back-patch to all
supported branches (which sadly no longer includes v10).

Discussion: https://postgr.es/m/65a899dd-aebc-f667-1d0a-abb89ff3abf8@enterprisedb.com

Branch
------
REL_14_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/ae47f8a9664a65b233ee3c716f3098a5ba71f615

Modified Files
--------------
doc/src/sgml/libpq.sgml           |  5 +++--
doc/src/sgml/protocol.sgml        |  9 +++++----
src/backend/access/transam/xact.c | 28 ++++++++++++++++++----------
src/backend/tcop/postgres.c       | 12 ++++++++++++
src/include/access/xact.h         |  7 +++++++
5 files changed, 45 insertions(+), 16 deletions(-)


В списке pgsql-committers по дате отправления:

Предыдущее
От: Peter Eisentraut
Дата:
Сообщение: pgsql: basebackup_to_shell: Add some const qualifiers for consistency
Следующее
От: Michael Paquier
Дата:
Сообщение: pgsql: Remove SHA256_HMAC_B from scram-common.h