]> granicus.if.org Git - postgresql/commit
Fix bug in clean shutdown of walsender that pg_receiving is connecting to.
authorFujii Masao <fujii@postgresql.org>
Mon, 17 Mar 2014 11:37:50 +0000 (20:37 +0900)
committerFujii Masao <fujii@postgresql.org>
Mon, 17 Mar 2014 11:37:50 +0000 (20:37 +0900)
commit5c6d9fc4b2b8b6688a482a4b4116d7642e36b9d9
tree0c8feb9bedd77f15cc5f83764dd502d504647c20
parent02703ff2277791a7f1bccf61124bee830f2b5fcb
Fix bug in clean shutdown of walsender that pg_receiving is connecting to.

On clean shutdown, walsender waits for all WAL to be replicated to a standby,
and exits. It determined whether that replication had been completed by
checking whether its sent location had been equal to a standby's flush
location. Unfortunately this condition never becomes true when the standby
such as pg_receivexlog which always returns an invalid flush location is
connecting to walsender, and then walsender waits forever.

This commit changes walsender so that it just checks a standby's write
location if a flush location is invalid.

Back-patch to 9.1 where enough infrastructure for this exists.
src/backend/replication/walsender.c