pgsql: Make dblink interruptible, via new libpqsrv APIs.

Поиск
Список
Период
Сортировка
От Noah Misch
Тема pgsql: Make dblink interruptible, via new libpqsrv APIs.
Дата
Msg-id E1rMvV2-000VtV-DF@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Make dblink interruptible, via new libpqsrv APIs.

This replaces dblink's blocking libpq calls, allowing cancellation and
allowing DROP DATABASE (of a database not involved in the query).  Apart
from explicit dblink_cancel_query() calls, dblink still doesn't cancel
the remote side.  The replacement for the blocking calls consists of
new, general-purpose query execution wrappers in the libpqsrv facility.
Out-of-tree extensions should adopt these.  Use them in postgres_fdw,
replacing a local implementation from which the libpqsrv implementation
derives.  This is a bug fix for dblink.  Code inspection identified the
bug at least thirteen years ago, but user complaints have not appeared.
Hence, no back-patch for now.

Discussion: https://postgr.es/m/20231122012945.74@rfd.leadboat.com

Branch
------
master

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

Modified Files
--------------
contrib/dblink/dblink.c                            |  28 +++--
contrib/postgres_fdw/connection.c                  |  88 +++-----------
contrib/postgres_fdw/deparse.c                     |   2 +-
contrib/postgres_fdw/postgres_fdw.c                |  10 +-
contrib/postgres_fdw/postgres_fdw.h                |   2 +-
doc/src/sgml/dblink.sgml                           |   9 ++
.../libpqwalreceiver/libpqwalreceiver.c            |   9 +-
src/include/libpq/libpq-be-fe-helpers.h            | 127 +++++++++++++++++++++
8 files changed, 180 insertions(+), 95 deletions(-)


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

Предыдущее
От: Alexander Korotkov
Дата:
Сообщение: pgsql: Fix indentation in ExecParallelHashIncreaseNumBatches()
Следующее
От: Alexander Korotkov
Дата:
Сообщение: pgsql: Fix misuse of RelOptInfo.unique_for_rels cache by SJE