pgsql: Fix handling of errors in libpq pipelines

Поиск
Список
Период
Сортировка
От Alvaro Herrera
Тема pgsql: Fix handling of errors in libpq pipelines
Дата
Msg-id E1rATqH-008hbf-JU@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Fix handling of errors in libpq pipelines

The logic to keep the libpq command queue in sync with queries that have
been processed had a bug when errors were returned for reasons other
than problems in queries -- for example, when a connection is lost.  We
incorrectly consumed an element from the command queue every time, but
this is wrong and can lead to the queue becoming empty ahead of time,
leading to later malfunction: PQgetResult would return nothing,
potentially causing the calling application to enter a busy loop.

Fix by making the SYNC queue element a barrier that can only be consumed
when a SYNC message is received.

Backpatch to 14.

Reported by: Иван Трофимов (Ivan Trofimov) <i.trofimow@yandex.ru>
Discussion: https://postgr.es/m/17948-fcace7557e449957@postgresql.org

Branch
------
master

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

Modified Files
--------------
src/interfaces/libpq/fe-exec.c      | 53 +++++++++++++++++++++++++------------
src/interfaces/libpq/fe-protocol3.c |  9 ++-----
src/interfaces/libpq/libpq-int.h    |  3 ++-
3 files changed, 40 insertions(+), 25 deletions(-)


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

Предыдущее
От: Amit Kapila
Дата:
Сообщение: pgsql: Fix a random failure in 003_logical_slots.pl.
Следующее
От: Daniel Gustafsson
Дата:
Сообщение: pgsql: Fix incorrect error message for IDENTIFY_SYSTEM