两段提交协议(Two Phase Commit Protocol--2PC)

两阶段提交协议(two phase commit protocol,2PC)可以保证数据的强一致性,许多分布式关系型数据管理系统采用此协议来完成分布式事务。它是协调所有分布式原子事务参与者,并决定提交或取消(回滚)的分布式算法。同时也是解决一致性问题的一致性算法。

在两阶段提交协议中,系统一般包含两类机器(或节点):一类为协调者(coordinator),通常一个系统中只有一个;另一类为事务参与者(participants,cohorts或workers),一般包含多个,在数据存储系统中可以理解为数据副本的个数。

顾名思义,两阶段提交协议由两个阶段组成。在正常的执行下,这两个阶段的执行过程如下所述:
阶段1:请求阶段(commit-request phase,或称表决阶段,voting phase)
在请求阶段,协调者将通知事务参与者准备提交或取消事务,然后进入表决过程。在表决过程中,参与者将告知协调者自己的决策:同意(事务参与者本地作业执行成功)或取消(本地作业执行故障)。

阶段2:提交阶段(commit phase)
在该阶段,协调者将基于第一个阶段的投票结果进行决策:提交或取消。当且仅当所有的参与者同意提交事务协调者才通知所有的参与者提交事务,否则协调者将通知所有的参与者取消事务。参与者在接收到协调者发来的消息后将执行响应的操作。

伪代码实现:

con1 = XAResouce1.getConnection...  
con2 = XAResouce2.getConnection...  
  
con1 do  some thing.  
con2 do  some thing.  
after they finish.  
  
pre1 = XAResouce1.prepare();  
pre2 = XAResouce2.prepare();  
  
if ( both pre1 and pre2 are OK){  
XAResouce1 and 2  commit  
}else  {  
XAResouce1 and 2  rollback  
}  

你可能感兴趣的:(两段提交协议(Two Phase Commit Protocol--2PC))