66.4. Two-Phase Transactions #
PostgreSQL supports a two-phase commit (2PC) protocol that allows multiple distributed systems to work together in a transactional manner. The commands are PREPARE TRANSACTION
, COMMIT PREPARED
and ROLLBACK PREPARED
. Two-phase transactions are intended for use by external transaction management systems. PostgreSQL follows the features and model proposed by the X/Open XA standard, but does not implement some less often used aspects.
When the user executes PREPARE TRANSACTION
, the only possible next commands are COMMIT PREPARED
or ROLLBACK PREPARED
. In general, this prepared state is intended to be of very short duration, but external availability issues might mean transactions stay in this state for an extended interval. Short-lived prepared transactions are stored only in shared memory and WAL. Transactions that span checkpoints are recorded in the pg_twophase
directory. Transactions that are currently prepared can be inspected using pg_prepared_xacts
.