Commit 280c53ec authored by Fujii Masao's avatar Fujii Masao

A collection of small fixes for logical replication.

* Be sure to reset the launcher's pid (LogicalRepCtx->launcher_pid) to 0
  even when the launcher emits an error.

* Declare ApplyLauncherWakeup() as a static function because it's called
  only in launcher.c.

* Previously IsBackendPId() was used to check whether the launcher's pid
  was valid. IsBackendPid() was necessary because there was the bug where
  the launcher's pid was not reset to 0. But now it's fixed, so IsBackendPid()
  is not necessary and this patch removes it.

Author: Masahiko Sawada
Reviewed-by: Kyotaro Horiguchi
Reported-by: Fujii Masao
Discussion: http://postgr.es/m/CAHGQGwFDWh_Qr-q_GEMpD+qH=vYPMdVqw=ZOSY3kX_Pna9R9SA@mail.gmail.com
parent 39a6772d
...@@ -72,6 +72,8 @@ typedef struct LogicalRepCtxStruct ...@@ -72,6 +72,8 @@ typedef struct LogicalRepCtxStruct
LogicalRepCtxStruct *LogicalRepCtx; LogicalRepCtxStruct *LogicalRepCtx;
static void ApplyLauncherWakeup(void);
static void logicalrep_launcher_onexit(int code, Datum arg);
static void logicalrep_worker_onexit(int code, Datum arg); static void logicalrep_worker_onexit(int code, Datum arg);
static void logicalrep_worker_detach(void); static void logicalrep_worker_detach(void);
...@@ -480,6 +482,17 @@ logicalrep_worker_detach(void) ...@@ -480,6 +482,17 @@ logicalrep_worker_detach(void)
LWLockRelease(LogicalRepWorkerLock); LWLockRelease(LogicalRepWorkerLock);
} }
/*
* Cleanup function for logical replication launcher.
*
* Called on logical replication launcher exit.
*/
static void
logicalrep_launcher_onexit(int code, Datum arg)
{
LogicalRepCtx->launcher_pid = 0;
}
/* /*
* Cleanup function. * Cleanup function.
* *
...@@ -643,10 +656,10 @@ ApplyLauncherWakeupAtCommit(void) ...@@ -643,10 +656,10 @@ ApplyLauncherWakeupAtCommit(void)
on_commit_launcher_wakeup = true; on_commit_launcher_wakeup = true;
} }
void static void
ApplyLauncherWakeup(void) ApplyLauncherWakeup(void)
{ {
if (IsBackendPid(LogicalRepCtx->launcher_pid)) if (LogicalRepCtx->launcher_pid != 0)
kill(LogicalRepCtx->launcher_pid, SIGUSR1); kill(LogicalRepCtx->launcher_pid, SIGUSR1);
} }
...@@ -659,6 +672,8 @@ ApplyLauncherMain(Datum main_arg) ...@@ -659,6 +672,8 @@ ApplyLauncherMain(Datum main_arg)
ereport(DEBUG1, ereport(DEBUG1,
(errmsg("logical replication launcher started"))); (errmsg("logical replication launcher started")));
before_shmem_exit(logicalrep_launcher_onexit, (Datum) 0);
/* Establish signal handlers. */ /* Establish signal handlers. */
pqsignal(SIGHUP, logicalrep_worker_sighup); pqsignal(SIGHUP, logicalrep_worker_sighup);
pqsignal(SIGTERM, logicalrep_worker_sigterm); pqsignal(SIGTERM, logicalrep_worker_sigterm);
......
...@@ -21,7 +21,6 @@ extern void ApplyLauncherMain(Datum main_arg); ...@@ -21,7 +21,6 @@ extern void ApplyLauncherMain(Datum main_arg);
extern Size ApplyLauncherShmemSize(void); extern Size ApplyLauncherShmemSize(void);
extern void ApplyLauncherShmemInit(void); extern void ApplyLauncherShmemInit(void);
extern void ApplyLauncherWakeup(void);
extern void ApplyLauncherWakeupAtCommit(void); extern void ApplyLauncherWakeupAtCommit(void);
extern void AtCommit_ApplyLauncher(void); extern void AtCommit_ApplyLauncher(void);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment