]> granicus.if.org Git - postgresql/commitdiff
Stop bgworkers during fast shutdown with postmaster in startup phase
authorMichael Paquier <michael@paquier.xyz>
Thu, 30 Aug 2018 00:11:27 +0000 (17:11 -0700)
committerMichael Paquier <michael@paquier.xyz>
Thu, 30 Aug 2018 00:11:27 +0000 (17:11 -0700)
When a postmaster gets into its phase PM_STARTUP, it would start
background workers using BgWorkerStart_PostmasterStart mode immediately,
which would cause problems for a fast shutdown as the postmaster forgets
to send SIGTERM to already-started background workers.  With smart and
immediate shutdowns, this correctly happened, and fast shutdown is the
only mode missing the shot.

Author: Alexander Kukushkin
Reviewed-by: Michael Paquier
Discussion: https://postgr.es/m/CAFh8B=mvnD8+DZUfzpi50DoaDfZRDfd7S=gwj5vU9GYn8UvHkA@mail.gmail.com
Backpatch-through: 9.5

src/backend/postmaster/postmaster.c

index bbef1a119dacd69ad769e7645f15a56489ccc75b..64337c266d4d2f315d3eca92f0836c894dd76724 100644 (file)
@@ -2686,7 +2686,7 @@ pmdie(SIGNAL_ARGS)
                                signal_child(BgWriterPID, SIGTERM);
                        if (WalReceiverPID != 0)
                                signal_child(WalReceiverPID, SIGTERM);
-                       if (pmState == PM_RECOVERY)
+                       if (pmState == PM_STARTUP || pmState == PM_RECOVERY)
                        {
                                SignalSomeChildren(SIGTERM, BACKEND_TYPE_BGWORKER);