SpringCloud - 分布式事务

16.谈谈你对分布式事务的理解?

由于单体事务在不同的微服务中,无法保证全局事务的ACID特性。比如创建订单成功,购物车页清理成功了,但是扣减库存失败,此时购物车中的商品信息也清空了,无法回滚。

Seata是解决分布式事务的中间件,Seata事务管理有三个重要的角色,分别是TC事务协调者、TM事务管理器以及RM资源管理器。其中TC可以协调全局事务提交回滚,TM向TC报告方法的开始和结束,RM负责管理分支事务提交或回滚。

Seata中提供了四种不同的分布式事务解决方案,分别是XATCCATSAGA,我们项目中使用的是AT,在这里主要讲下XA和AT,XA和AT都是采用两阶段提交来解决分支事务问题。

  1. XA就是分支事务执行完SQL语句后,会使用锁来锁定资源,通过RM向TC汇报事务状态。如果TC发现有的分支事务没有执行成功,就通知所有的分支事务进行回滚。如果所有的分支事务都执行成功,那么TC就通知所有的分支事务提交。XA在第一阶段不提交事务,在第二阶段提交或者回滚。可以满足事务的强一致性,但是性能比较差。
  2. AT会先在undo log日志中记录更新前的快照,分支事务执行完SQL之后直接提交,然后向TC汇报事务状态。如果有分支事务没有执行成功,那么TC就通知所有的分支事务回滚,那么分支事务就通过各自的undo log日志恢复数据。如果所有的分支事务都成执行成功,那么就通知分支事务进行提交,分支事务收到提交命令之后直接删除undo log日志中的数据。AT在第一阶段就提交了事务,可以保证最终一致性,但是不能保证强一致性,性能比较好。
相关推荐
布局呆星8 小时前
SpringBoot 基础入门
java·spring boot·spring
不懂的浪漫9 小时前
mqtt-plus 架构解析(六):多 Broker 管理,如何让一个应用同时连接多个 MQTT 服务
spring boot·分布式·物联网·mqtt·架构
❀͜͡傀儡师13 小时前
Spring AI Alibaba vs. AgentScope:两个阿里AI框架,如何选择?
java·人工智能·spring
亦暖筑序15 小时前
手写 Spring AI Agent:让大模型自主规划任务,ReAct 模式全流程拆解
java·人工智能·spring
小夏子_riotous16 小时前
openstack的使用——5. Swift服务的基本使用
linux·运维·开发语言·分布式·云计算·openstack·swift
刘~浪地球17 小时前
消息队列--Kafka 生产环境最佳实践
分布式·kafka·linq
juniperhan18 小时前
Flink 系列第8篇:Flink Checkpoint 全解析(原理+流程+配置+优化)
大数据·分布式·flink
lvyuanj19 小时前
zookeeper_cluster
分布式·zookeeper·云原生
希望永不加班19 小时前
SpringBoot 配置绑定:@ConfigurationProperties
java·spring boot·后端·spring
white-persist19 小时前
【vulhub spring CVE-2018-1270】CVE-2018-1270 Spring Messaging 远程命令执行漏洞 完整复现详细分析解释
java·服务器·网络·数据库·后端·python·spring