-
- Downloads
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
Showing
- src/backend/access/transam/README 15 additions, 6 deletionssrc/backend/access/transam/README
- src/backend/access/transam/clog.c 214 additions, 15 deletionssrc/backend/access/transam/clog.c
- src/backend/access/transam/transam.c 27 additions, 117 deletionssrc/backend/access/transam/transam.c
- src/backend/access/transam/twophase.c 3 additions, 6 deletionssrc/backend/access/transam/twophase.c
- src/backend/access/transam/xact.c 13 additions, 59 deletionssrc/backend/access/transam/xact.c
- src/include/access/clog.h 3 additions, 2 deletionssrc/include/access/clog.h
- src/include/access/transam.h 4 additions, 7 deletionssrc/include/access/transam.h
Loading
Please register or sign in to comment