]> 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:10:13 +0000 (17:10 -0700)
committerMichael Paquier <michael@paquier.xyz>
Thu, 30 Aug 2018 00:10:13 +0000 (17:10 -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 a4b53b33cdde912cc0d4639d8c7d27c0ae6693de..2215ebbb5a5618f6f450b87f6b95cafe904c58b0 100644 (file)
@@ -2685,7 +2685,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);