三阶段提交(3PC,Three-Phase Commit)是分布式系统中用于保证事务原子性和一致性的协议之一。它是在两阶段提交(2PC,Two-Phase Commit)的基础上改进而来的,目的是为了减少在协调者(Coordinator)失败时的阻塞问题。3PC将整个提交过程分为三个阶段,分别是:
CanCommit(准备阶段):
- 协调者向所有参与者(Participants)询问是否可以提交事务,并等待所有参与者的回复。
- 参与者执行事务操作,但并不提交,而是将操作保存到一个临时状态中,并返回给协调者是否可以继续。
PreCommit(预提交阶段):
- 如果协调者收到所有参与者的肯定回复,它会向所有参与者发送预提交请求,要求参与者进入预提交状态。
- 参与者在收到预提交请求后,将事务标记为预提交状态,并记录下这个状态,但是不真正提交事务。
DoCommit(提交阶段):
- 协调者根据预提交阶段的结果决定是否正式提交事务。如果决定提交,它会向所有参与者发送提交命令;如果决定不提交,则向所有参与者发送回滚命令。
- 参与者在收到提交命令后,正式提交事务并释放所有资源锁;如果是回滚命令,则进行事务回滚并释放资源锁。
3PC通过引入预提交阶段,减少了因协调者失败导致的阻塞情况。在预提交阶段,即使协调者失败,参与者也可以根据预提交状态自行完成事务的提交或回滚,无需等待协调者再次发出指令。
然而,3PC也有其缺点,例如,相比2PC,它的网络通信次数更多,这可能会增加系统的延迟和开销。此外,在某些情况下,如果参与者在预提交阶段之后、最终提交之前失败,恢复过程可能变得复杂。