分布式事务解决方案2pc

为解决分布式系统的数据一致性问题出现了两阶段提交协议,两阶段提交由 协调者和参与者组成,共经过两个阶段和三个操作,部分关系数据库如OracleMySQL支持两阶段提交协议,这里讲解关系数据库两阶段提交协议。

2PC协议流程图:

1)第一阶段:准备阶段(prepare

协调者通知参与者准备提交订单,参与者开始投票。

协调者完成准备工作向协调者回应Yes

2)第二阶段:提交(commit)/回滚(rollback)阶段

协调者根据参与者的投票结果发起最终的提交指令。

如果有参与者没有准备好则发起回滚指令。

一个下单减库存的例子:

1、应用程序连接两个数据源。

2、应用程序通过事务协调器向两个库发起prepare,两个数据库收到消息分别执行本地事务(记录日志),但不提

交,如果执行成功则回复yes,否则回复no

3、事务协调器收到回复,只要有一方回复no则分别向参与者发起回滚事务,参与者开始回滚事务。

4、事务协调器收到回复,全部回复yes,此时向参与者发起提交事务。如果参与者有一方提交事务失败则由事务协

调器发起回滚事务。

2PC的优点:实现强一致性,部分关系数据库支持(OracleMySQL等)。

缺点:整个事务的执行需要由协调者在多个节点之间去协调,增加了事务的执行时间,性能低下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值