]> granicus.if.org Git - postgresql/commit
Fix various possible problems with synchronous replication.
authorRobert Haas <rhaas@postgresql.org>
Thu, 17 Mar 2011 17:10:42 +0000 (13:10 -0400)
committerRobert Haas <rhaas@postgresql.org>
Thu, 17 Mar 2011 17:12:21 +0000 (13:12 -0400)
commit9a56dc3389b9470031e9ef8e45c95a680982e01a
treeec20f12f1a2a01ace8fa595f85179c75699c3dce
parente148443ddd95cd29edf4cc1de6188eb9cee029c5
Fix various possible problems with synchronous replication.

1. Don't ignore query cancel interrupts.  Instead, if the user asks to
cancel the query after we've already committed it, but before it's on
the standby, just emit a warning and let the COMMIT finish.

2. Don't ignore die interrupts (pg_terminate_backend or fast shutdown).
Instead, emit a warning message and close the connection without
acknowledging the commit.  Other backends will still see the effect of
the commit, but there's no getting around that; it's too late to abort
at this point, and ignoring die interrupts altogether doesn't seem like
a good idea.

3. If synchronous_standby_names becomes empty, wake up all backends
waiting for synchronous replication to complete.  Without this, someone
attempting to shut synchronous replication off could easily wedge the
entire system instead.

4. Avoid depending on the assumption that if a walsender updates
MyProc->syncRepState, we'll see the change even if we read it without
holding the lock.  The window for this appears to be quite narrow (and
probably doesn't exist at all on machines with strong memory ordering)
but protecting against it is practically free, so do that.

5. Remove useless state SYNC_REP_MUST_DISCONNECT, which isn't needed and
doesn't actually do anything.

There's still some further work needed here to make the behavior of fast
shutdown plausible, but that looks complex, so I'm leaving it for a
separate commit.  Review by Fujii Masao.
doc/src/sgml/config.sgml
src/backend/postmaster/walwriter.c
src/backend/replication/syncrep.c
src/backend/tcop/postgres.c
src/include/replication/syncrep.h
src/include/replication/walsender.h