Encyclopedia of Database Systems

2018 Edition
| Editors: Ling Liu, M. Tamer Özsu

Two-Phase Commit Protocol

  • Jens Lechtenbörger
Reference work entry
DOI: https://doi.org/10.1007/978-1-4614-8265-9_2

Synonyms

XA standard

Definition

The two-phase commit (2PC) protocol is a distributed algorithm to ensure the consistent termination of a transaction in a distributed environment. Thus, via 2PC a unanimous decision is reached and enforced among multiple participating servers whether to commit or abort a given transaction, thereby guaranteeing atomicity. The protocol proceeds in two phases, namely, the prepare (or voting) and the commit (or decision) phase, which explains the protocol’s name.

The protocol is executed by a coordinator process, while the participating servers are called participants. When the transaction’s initiator issues a request to commit the transaction, the coordinator starts the first phase of the 2PC protocol by querying – via prepare messages – all participants whether to abort or to commit the transaction. If all participants vote to commit, then in the second phase, the coordinator informs all participants to commit their share of the transaction by sending a com...

This is a preview of subscription content, log in to check access.

Recommended Reading

  1. 1.
    Cabrera LF et al. Web services atomic transaction, 2005.Google Scholar
  2. 2.
    Gray J. Notes on database operating systems. In: Bayer R, Graham MR, Seegmüller G, editors. Operating systems: an advanced course, Lecture notes in computer science, vol. 60. Berlin: Springer; 1978. p. 393–481.CrossRefGoogle Scholar
  3. 3.
    Gray J, Reuter A. Transaction processing: concepts and techniques. San Francisco: Morgan Kaufmann; 1993.zbMATHGoogle Scholar
  4. 4.
    Lampson BW, Sturgis H. Crash recovery in distributed data storage systems. Technical Report. Palo Alto: Xerox Palo Alto Research Center.Google Scholar
  5. 5.
  6. 6.
    Sun Microsystems. Java Transaction API (JTA). http://java.sun.com/jta/; http://java.sun.com/jta/ (2007).
  7. 7.
    The Open GROUP Distributed Transaction Processing: The XA Specification. X/Open Company Ltd, ISBN 1 872630 24 3; 1991.Google Scholar
  8. 8.
    Weikum G, Vossen G. Transactional information systems – theory, algorithms, and the practice of concurrency control and recovery. San Francisco: Morgan Kaufmann; 2002.Google Scholar

Copyright information

© Springer Science+Business Media, LLC, part of Springer Nature 2018

Authors and Affiliations

  1. 1.University of MünsterMünsterGermany

Section editors and affiliations

  • Gottfried Vossen
    • 1
  1. 1.Dep. of Inf. SystemsWestf. Wilhelms-UniveristätMünsterGermany