]> granicus.if.org Git - postgresql/commitdiff
Report WAL flush, not insert, position in replication IDENTIFY_SYSTEM
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>
Fri, 6 Feb 2015 09:18:14 +0000 (11:18 +0200)
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>
Fri, 6 Feb 2015 09:32:37 +0000 (11:32 +0200)
When beginning streaming replication, the client usually issues the
IDENTIFY_SYSTEM command, which used to return the current WAL insert
position. That's not suitable for the intended purpose of that field,
however. pg_receivexlog uses it to start replication from the reported
point, but if it hasn't been flushed to disk yet, it will fail. Change
IDENTIFY_SYSTEM to report the flush position instead.

Backpatch to 9.1 and above. 9.0 doesn't report any WAL position.

doc/src/sgml/protocol.sgml
src/backend/replication/walsender.c

index 08c2f008936b76e4f0f339028ae85d0c3ebc358b..87741f3b374b98447acf4a190947d151e8632210 100644 (file)
@@ -1338,7 +1338,7 @@ The commands accepted in walsender mode are:
       </term>
       <listitem>
       <para>
-       Current xlog write location. Useful to get a known location in the
+       Current xlog flush location. Useful to get a known location in the
        transaction log where streaming can start.
       </para>
       </listitem>
index 7deaa82fd64ea96e551b0ad587b4d56e6c93b3d0..94da622f057ccbc9771997b3c1bf4d1dd73f86ca 100644 (file)
@@ -298,7 +298,7 @@ IdentifySystem(void)
                         GetSystemIdentifier());
        snprintf(tli, sizeof(tli), "%u", ThisTimeLineID);
 
-       logptr = am_cascading_walsender ? GetStandbyFlushRecPtr(NULL) : GetInsertRecPtr();
+       logptr = am_cascading_walsender ? GetStandbyFlushRecPtr(NULL) : GetFlushRecPtr();
 
        snprintf(xpos, sizeof(xpos), "%X/%X",
                         logptr.xlogid, logptr.xrecoff);