Fix pg_dump's sigTermHandler() to use _exit() not exit().
authorTom Lane
Mon, 20 Jan 2020 17:57:17 +0000 (12:57 -0500)
committerTom Lane
Mon, 20 Jan 2020 17:57:17 +0000 (12:57 -0500)
commit71b121f425486c2a02f88f90e2a7c852182b5af0
treee28b6bf902b883b74d6fffbb5583febf000c6b97
parentfd436bba01f6df843a9f421669c02e2b970fdc7a
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
src/bin/pg_dump/parallel.c