Make archiver's SIGQUIT handler exit via _exit().
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 9 Sep 2020 19:32:34 +0000 (15:32 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 9 Sep 2020 19:32:34 +0000 (15:32 -0400)
commitb2eaddd9b00acad80d634ec671235a080269bd72
tree09fb74c95c67c4db3f37b34e72d0d82add3a2254
parent27acbd51e60c98cba6441d7a88210a1c33bf9db4
Make archiver's SIGQUIT handler exit via _exit().

Commit 8e19a8264 changed the SIGQUIT handlers of almost all server
processes not to run atexit callbacks.  The archiver process was
skipped, perhaps because it's not connected to shared memory; but
it's just as true here that running atexit callbacks in a signal
handler is unsafe.  So let's make it work like the rest.

In HEAD and v13, we can use the common SignalHandlerForCrashExit
handler.  Before that, just tweak pgarch_exit to use _exit(2)
explicitly.

Like the previous commit, back-patch to all supported branches.

Kyotaro Horiguchi, back-patching by me

Discussion: https://postgr.es/m/1850884.1599601164@sss.pgh.pa.us
src/backend/postmaster/pgarch.c