OSDN Git Service

Rework subtransaction commit protocol for hot standby.
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Mon, 20 Oct 2008 19:18:18 +0000 (19:18 +0000)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Mon, 20 Oct 2008 19:18:18 +0000 (19:18 +0000)
commit06da3c570f21394003fc392d80f54862f7dec19f
tree2e4c5dc1cb78d87e12fc1495b084bfaf5e69e737
parent3afffbc902f16f5b9abd2464a2bbc17d9bc63316
Rework subtransaction commit protocol for hot standby.

This patch eliminates the marking of subtransactions as SUBCOMMITTED in pg_clog
during their commit; instead they remain in-progress until main transaction
commit.  At main transaction commit, the commit protocol is atomic-by-page
instead of one transaction at a time.  To avoid a race condition with some
subtransactions appearing committed before others in the case where they span
more than one pg_clog page, we conserve the logic that marks them subcommitted
before marking the parent committed.

Simon Riggs with minor help from me
src/backend/access/transam/README
src/backend/access/transam/clog.c
src/backend/access/transam/transam.c
src/backend/access/transam/twophase.c
src/backend/access/transam/xact.c
src/include/access/clog.h
src/include/access/transam.h