欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

分布式一致性协议-2PC与3PC(二)

程序员文章站 2022-03-07 16:39:19
一、分布式一致性 一个事务需要跨多个分布式节点,又要保持事务的ACID特性,需要引入协调者来统一调度所有分布式节点的执行逻辑,被调度的节点称为参与者。 协调者负责调用参与者,并决定最终是否提交事务。基于这个思想,衍生出2PC和3PC两种协议 二、2PC协议(Two phase commit) 二阶段 ......

一、分布式一致性

一个事务需要跨多个分布式节点,又要保持事务的ACID特性,需要引入协调者来统一调度所有分布式节点的执行逻辑,被调度的节点称为参与者

协调者负责调用参与者,并决定最终是否提交事务。基于这个思想,衍生出2PC和3PC两种协议

二、2PC协议(Two phase commit)

二阶段提交:将事务分成了投票和执行两个阶段。

优点:原理简单

缺点:单点问题、同步阻塞、无限期等待、脑裂

事务提交场景:

分布式一致性协议-2PC与3PC(二)

 

事务回滚场景:

分布式一致性协议-2PC与3PC(二)

 三、3PC(Three phase commit)

 三阶段提交:将2PC的执行事务过程一分为二,形成canCommit、preCommit、doCommit三个阶段的事务处理协议。

 优点:解决单点问题、添加preCommit过程,避免2PC提交协议的无限期等待问题

 缺点:一旦出现网络分区协调者与参与者无法通信,参与者在超时之后,依然会提交事务,造成数据不一致

分布式一致性协议-2PC与3PC(二)