Commit 981524d2 authored by Fujii Masao's avatar Fujii Masao

Make archiver process handle barrier events.

Commit d75288fb made WAL archiver process an auxiliary process.
An auxiliary process needs to handle barrier events but the commit
forgot to make archiver process do that.

Reported-by: Thomas Munro
Author: Fujii Masao
Reviewed-by: Thomas Munro
Discussion: https://postgr.es/m/CA+hUKGLah2w1pWKHonZP_+EQw69=q56AHYwCgEN8GDzsRG_Hgw@mail.gmail.com
parent f80979f6
...@@ -102,6 +102,7 @@ static bool pgarch_archiveXlog(char *xlog); ...@@ -102,6 +102,7 @@ static bool pgarch_archiveXlog(char *xlog);
static bool pgarch_readyXlog(char *xlog); static bool pgarch_readyXlog(char *xlog);
static void pgarch_archiveDone(char *xlog); static void pgarch_archiveDone(char *xlog);
static void pgarch_die(int code, Datum arg); static void pgarch_die(int code, Datum arg);
static void HandlePgArchInterrupts(void);
/* Report shared memory space needed by PgArchShmemInit */ /* Report shared memory space needed by PgArchShmemInit */
Size Size
...@@ -257,12 +258,8 @@ pgarch_MainLoop(void) ...@@ -257,12 +258,8 @@ pgarch_MainLoop(void)
/* When we get SIGUSR2, we do one more archive cycle, then exit */ /* When we get SIGUSR2, we do one more archive cycle, then exit */
time_to_stop = ready_to_stop; time_to_stop = ready_to_stop;
/* Check for config update */ /* Check for barrier events and config update */
if (ConfigReloadPending) HandlePgArchInterrupts();
{
ConfigReloadPending = false;
ProcessConfigFile(PGC_SIGHUP);
}
/* /*
* If we've gotten SIGTERM, we normally just sit and do nothing until * If we've gotten SIGTERM, we normally just sit and do nothing until
...@@ -355,15 +352,11 @@ pgarch_ArchiverCopyLoop(void) ...@@ -355,15 +352,11 @@ pgarch_ArchiverCopyLoop(void)
return; return;
/* /*
* Check for config update. This is so that we'll adopt a new * Check for barrier events and config update. This is so that
* setting for archive_command as soon as possible, even if there * we'll adopt a new setting for archive_command as soon as
* is a backlog of files to be archived. * possible, even if there is a backlog of files to be archived.
*/ */
if (ConfigReloadPending) HandlePgArchInterrupts();
{
ConfigReloadPending = false;
ProcessConfigFile(PGC_SIGHUP);
}
/* can't do anything if no command ... */ /* can't do anything if no command ... */
if (!XLogArchiveCommandSet()) if (!XLogArchiveCommandSet())
...@@ -703,3 +696,23 @@ pgarch_die(int code, Datum arg) ...@@ -703,3 +696,23 @@ pgarch_die(int code, Datum arg)
{ {
PgArch->pgprocno = INVALID_PGPROCNO; PgArch->pgprocno = INVALID_PGPROCNO;
} }
/*
* Interrupt handler for WAL archiver process.
*
* This is called in the loops pgarch_MainLoop and pgarch_ArchiverCopyLoop.
* It checks for barrier events and config update, but not shutdown request
* because how to handle shutdown request is different between those loops.
*/
static void
HandlePgArchInterrupts(void)
{
if (ProcSignalBarrierPending)
ProcessProcSignalBarrier();
if (ConfigReloadPending)
{
ConfigReloadPending = false;
ProcessConfigFile(PGC_SIGHUP);
}
}
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