2PC
是计算机网络尤其是在数据库领域内,为了使基于分布式系统架构下的所有节点在进行事务处理过程中能够保持原子性和一致性而设计的算法。
协议说明
2PC是将事务的提交过程分成了两个阶段进行处理
阶段一:提交事务请求(投票阶段)
阶段二:执行事务提交(执行阶段)
在阶段二中,协调者会根据参与者的反馈情况来决定最终是否可以进行事务提交操作,正常情况下,包含以下两种可能
执行事务提交
中断事务
简单来说,2PC将一个事务的处理过程分为投票和执行两个阶段,其核心是对每个事务都采用先尝试后提交的处理方式,因此可以将2PC看作是一个强一致性的算法。
优缺点
2PC优点:原理简单,实现方便
2PC缺点:同步阻塞、单点问题、脑裂、太过保守
3PC
是2PC的改进版,其将二阶段提交协议的“提交事务请求”过程一分为二,形成了由canCommit、preCommit、 doCommit 三个阶段组成的事务处理协议
协议说明