Seata系列之(二)Seata简介

Seata简介

SpringCloud Alibaba Seata处理分布式事务

1. 是什么

Seata(Simple Extensible Autonomous Transaction Architecture,简单可扩展自治事务框架)一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务

官网:http://seata.io/zh-cn/

2. Seata的分布式事务处理过程🔥🔥🔥

Seata是如何处理分布式事务的

全局唯一的事务ID(Transaction ID XID) + 三组件模型

三组件模型

  • Transaction Coordinator(TC) :事务协调者,维护全局和分支事务的状态,驱动全局事务提交或回滚。
  • Transaction Manager(TM) :事务管理器,定义全局事务的范围:开始全局事务、提交或回滚全局事务。
  • Resource Manager(RM) :资源管理器,管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。(管理数据库)

  1. TM向TC申请开启一个全局事务,全局事务创建成功并生成一个全局唯一的XID;
  2. XID在微服务调用链路的上下文中传播;
  3. RM向TC注册分支事务(向TC提供RM自身的身份信息),将其纳入XID对应全局事务的管辖;
  4. TM向TC发起针对 XID的全局提交或回滚决议;
  5. TC调度XID下管辖的全部分支事务完成提交或回滚请求。

我(TC)来讲,他(TM)来管,大家(RM)来听

3. 怎么玩

本地事务:@Transactional,Spring提供的

全局事务:@GlobalTransactional,SpringCloudAlibaba提供的

posted @   刘二水  阅读(12)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示