分布式架构设计篇(九)-柔性事务之Saga详解

                                                                                             -     起源     -

Saga模型起源于1987年 Hector Garcia-Molina,Kenneth Salem 发表的论文《Sagas》,是分布式事务相关概念最早出现的。

Saga模型是把一个分布式事务拆分为多个本地事务,每个本地事务都有相应的执行模块和补偿模块(对应TCC中的Confirm和Cancel),当Saga事务中任意一个本地事务出错时,可以通过调用相关的补偿方法恢复之前的事务,达到事务最终一致性。

                                                                                          -     组成     -

  • Saga模型主要分:

    •  一串子事务(本地事务)的事务链

    • 每个Saga子事务Tn, 都有对应的补偿定义 Cn用于撤销Tn造成的结果

    • 每个Tn都没有“预留”动作,直接提交到库。

  • 执行顺序:

    • 子事务序列 T1, T2, …, Tn得以完成 (最佳情况)

    • 或者序列 T1, T2, …, Tj, Cj-1, …, C2, C1, 0 < j < n, 得以完成

  • 数据隔离性:

    • 业务层控制并发

    • 在应用层加锁

    • 应用层预先冻结资源等

  • 恢复方式:

    • 向后恢复:补偿所有已完成的事务,如果任一子事务失败

    • 向前恢复:重试失败的事务,假设每个子事务最终都会成功 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值