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
.