If the stats collector dies during Hot Standby, restart it.
authorRobert Haas
Thu, 27 Oct 2016 18:27:40 +0000 (14:27 -0400)
committerRobert Haas
Thu, 27 Oct 2016 18:54:35 +0000 (14:54 -0400)
This bug exists as far back as 9.0, when Hot Standby was introduced,
so back-patch to all supported branches.

Report and patch by Takayuki Tsunakawa, reviewed by Michael Paquier
and Kuntal Ghosh.

src/backend/postmaster/postmaster.c

index c834d2e3044daa700bf9320c77a2fb85a15f59b4..923fa3f2fd267f4a7b0d32ed4cb2a51395cc5b2b 100644 (file)
@@ -1753,7 +1753,8 @@ ServerLoop(void)
        }
 
        /* If we have lost the stats collector, try to start a new one */
-       if (PgStatPID == 0 && pmState == PM_RUN)
+       if (PgStatPID == 0 &&
+           (pmState == PM_RUN || pmState == PM_HOT_STANDBY))
            PgStatPID = pgstat_start();
 
        /* If we have lost the archiver, try to start a new one. */
@@ -2963,7 +2964,7 @@ reaper(SIGNAL_ARGS)
            if (!EXIT_STATUS_0(exitstatus))
                LogChildExit(LOG, _("statistics collector process"),
                             pid, exitstatus);
-           if (pmState == PM_RUN)
+           if (pmState == PM_RUN || pmState == PM_HOT_STANDBY)
                PgStatPID = pgstat_start();
            continue;
        }