mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-21 02:52:47 +03:00 
			
		
		
		
	Report WAL flush, not insert, position in replication IDENTIFY_SYSTEM
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.
This commit is contained in:
		| @@ -1350,7 +1350,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> | ||||
|   | ||||
| @@ -259,7 +259,7 @@ IdentifySystem(void) | ||||
| 		logptr = GetStandbyFlushRecPtr(); | ||||
| 	} | ||||
| 	else | ||||
| 		logptr = GetInsertRecPtr(); | ||||
| 		logptr = GetFlushRecPtr(); | ||||
|  | ||||
| 	snprintf(tli, sizeof(tli), "%u", ThisTimeLineID); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user