pgsql: Fix pg_dump's sigTermHandler() to use _exit() not exit().

Поиск
Список
Период
Сортировка
От Tom Lane
Тема pgsql: Fix pg_dump's sigTermHandler() to use _exit() not exit().
Дата
Msg-id E1itbJ1-0002mW-C9@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Fix pg_dump's sigTermHandler() to use _exit() not exit().

sigTermHandler() tried to be careful to invoke only operations that
are safe to do in a signal handler.  But for some reason we forgot
that exit(3) is not among those, because it calls atexit handlers
that might do various random things.  (pg_dump itself installs no
atexit handlers, but e.g. OpenSSL does.)  That led to crashes or
lockups when attempting to terminate a parallel dump or restore
via a signal.

Fix by calling _exit() instead.

Per bug #16199 from Raúl Marín.  Back-patch to all supported branches.

Discussion: https://postgr.es/m/16199-cb2f121146a96f9b@postgresql.org

Branch
------
REL9_4_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/42e538fe673b20d9adfc46bc889f3eb16ceb6538

Modified Files
--------------
src/bin/pg_dump/parallel.c | 7 +++++--
1 file changed, 5 insertions(+), 2 deletions(-)


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

Предыдущее
От: Heikki Linnakangas
Дата:
Сообщение: pgsql: Fix crash in BRIN inclusion op functions, due to missing datum c
Следующее
От: Tom Lane
Дата:
Сообщение: pgsql: Further tweaking of jsonb_set_lax().