Commit 49340627 authored by Simon Riggs's avatar Simon Riggs

Fix pg_receivexlog --synchronous

Make pg_receivexlog work correctly with --synchronous without slots

Backpatch to 9.5

Gabriele Bartolini, reviewed by Michael Paquier and Simon Riggs
parent bd082231
...@@ -503,25 +503,27 @@ ReceiveXlogStream(PGconn *conn, StreamCtl *stream) ...@@ -503,25 +503,27 @@ ReceiveXlogStream(PGconn *conn, StreamCtl *stream)
if (!CheckServerVersionForStreaming(conn)) if (!CheckServerVersionForStreaming(conn))
return false; return false;
if (replication_slot != NULL)
{
/* /*
* Report the flush position, so the primary can know what WAL we'll * Decide whether we want to report the flush position. If we report
* possibly re-request, and remove older WAL safely. * the flush position, the primary will know what WAL we'll
* possibly re-request, and it can then remove older WAL safely.
* We must always do that when we are using slots.
* *
* We only report it when a slot has explicitly been used, because * Reporting the flush position makes one eligible as a synchronous
* reporting the flush position makes one eligible as a synchronous
* replica. People shouldn't include generic names in * replica. People shouldn't include generic names in
* synchronous_standby_names, but we've protected them against it so * synchronous_standby_names, but we've protected them against it so
* far, so let's continue to do so in the situations when possible. If * far, so let's continue to do so unless specifically requested.
* they've got a slot, though, we need to report the flush position,
* so that the master can remove WAL.
*/ */
if (replication_slot != NULL)
{
reportFlushPosition = true; reportFlushPosition = true;
sprintf(slotcmd, "SLOT \"%s\" ", replication_slot); sprintf(slotcmd, "SLOT \"%s\" ", replication_slot);
} }
else else
{ {
if (stream->synchronous)
reportFlushPosition = true;
else
reportFlushPosition = false; reportFlushPosition = false;
slotcmd[0] = 0; slotcmd[0] = 0;
} }
......
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