【分布式事务】-Seata作为一款优秀的分布式事务解决方案,提供了多种可实现的事务模式,以满足不同的业务场景XA(强一致性、性能更差),AT(弱一致性、性能更好)

【分布式事务】-Seata作为一款优秀的分布式事务解决方案,提供了多种可实现的事务模式,以满足不同的业务场景XA(强一致性、性能更差),AT(弱一致性、性能更好)

Seata(Simple Extensible Autonomous Transaction Architecture)是一款开源的分布式事务解决方案,它提供了高性能和简单易用的分布式事务服务。Seata支持多种事务模式,以满足不同场景下的分布式事务处理需求。具体来说,Seata的分布式事务模式主要包括以下四种:

  1. AT模式(Auto Transaction)
    • 特点:无侵入的分布式事务解决方案,用户只需关注自己的业务SQL,Seata框架会自动生成事务的二阶段提交和回滚操作。
    • 流程
      1. 一阶段:拦截业务SQL,解析SQL语义,找到要更新的业务数据,并保存快照数据和行锁。
      2. 二阶段:如果是提交,则清理数据;如果是回滚,则用快照数据还原业务数据。
    • 适用场景:适用于不希望对业务进行改造的场景,几乎零学习成本。
    • 优点:实现简单,对业务代码零入侵;一阶段完成后提交事务,快速释放资源,性能较好。
    • 缺点:两阶段之间属于软状态,最终一致;快照生成和回滚等操作可能影响性能。
  2. TCC模式(Try-Confirm-Cancel)
    • 特点:高性能分布式事务解决方案,需要用户根据自己的业务场景实现Try、Confirm和Cancel三个操作。
    • 流程
      1. Try阶段:资源的检测和预留。
      2. Confirm阶段:执行业务操作提交。
      3. Cancel阶段:预留资源释放。
    • 适用场景:适用于核心系统等对性能有很高要求的场景。
    • 优点:一阶段完成后提交事务,快速释放资源,性能好;无需快照、无需全局锁。
    • 缺点:强代码入侵,需要手动写Try、Confirm、Cancel逻辑;需要考虑失败尝试和幂等问题。
  3. Saga模式
    • 特点:适用于长事务,由事件驱动,各个参与者之间异步执行。
    • 流程
      1. 参与者之间通过事件进行通信。
      2. 如果任何一个正向操作执行失败,则执行前面各参与者的逆向回滚操作。
    • 适用场景:适用于微服务架构下的复杂业务流程,允许一定范围内的最终一致性。
    • 优点:支持长事务和复杂的业务场景;各个参与者之间异步执行,提高系统可用性。
    • 缺点:可能存在数据不一致的风险;需要精心设计补偿操作。
  4. XA模式
    • 特点:基于XA协议的分布式事务解决方案,利用事务资源对XA协议的支持来管理分支事务。
    • 流程
      1. 一阶段:事务协调者通知每个事务参与者执行本地事务,但不提交。
      2. 二阶段:如果一阶段都成功,则通知所有参与者提交事务;如果有失败,则通知所有参与者回滚事务。
    • 适用场景:适用于需要强一致性的场景。
    • 优点:事务的强一致性,满足ACID原则;常用数据库都支持,实现简单。
    • 缺点:一阶段需要锁定数据库资源,等待二阶段结束才释放,性能较差;依赖关系型数据库实现事务。

综上所述,Seata的四种分布式事务模式各有优缺点和适用场景,用户可以根据实际需求选择合适的事务模式。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值