Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
After a crash, don't restart workers with BGW_NEVER_RESTART.
authorRobert Haas <rhaas@postgresql.org>
Thu, 2 Apr 2015 18:38:06 +0000 (14:38 -0400)
committerRobert Haas <rhaas@postgresql.org>
Thu, 2 Apr 2015 18:38:06 +0000 (14:38 -0400)
Amit Khandekar

src/backend/postmaster/bgworker.c

index cf7524f4921ef372b0370ddb3d5d811f3e761635..99f4b65ea658bda7935da7633cc24128dcecc47c 100644 (file)
@@ -419,9 +419,9 @@ BackgroundWorkerStopNotifications(pid_t pid)
 /*
  * Reset background worker crash state.
  *
- * We assume that, after a crash-and-restart cycle, background workers should
- * be restarted immediately, instead of waiting for bgw_restart_time to
- * elapse.
+ * We assume that, after a crash-and-restart cycle, background workers without
+ * the never-restart flag should be restarted immediately, instead of waiting
+ * for bgw_restart_time to elapse.
  */
 void
 ResetBackgroundWorkerCrashTimes(void)
@@ -433,7 +433,14 @@ ResetBackgroundWorkerCrashTimes(void)
        RegisteredBgWorker *rw;
 
        rw = slist_container(RegisteredBgWorker, rw_lnode, iter.cur);
-       rw->rw_crashed_at = 0;
+
+       /*
+        * For workers that should not be restarted, we don't want to lose
+        * the information that they have crashed; otherwise, they would be
+        * restarted, which is wrong.
+        */
+       if (rw->rw_worker.bgw_restart_time != BGW_NEVER_RESTART)
+           rw->rw_crashed_at = 0;
    }
 }