Seata系列之(二)Seata简介
Seata简介
SpringCloud Alibaba Seata处理分布式事务
1. 是什么
Seata(Simple Extensible Autonomous Transaction Architecture,简单可扩展自治事务框架)一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务
2. Seata的分布式事务处理过程🔥🔥🔥
Seata是如何处理分布式事务的
全局唯一的事务ID(Transaction ID XID) + 三组件模型
三组件模型
- Transaction Coordinator(TC) :事务协调者,维护全局和分支事务的状态,驱动全局事务提交或回滚。
- Transaction Manager(TM) :事务管理器,定义全局事务的范围:开始全局事务、提交或回滚全局事务。
- Resource Manager(RM) :资源管理器,管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。(管理数据库)
- TM向TC申请开启一个全局事务,全局事务创建成功并生成一个全局唯一的XID;
- XID在微服务调用链路的上下文中传播;
- RM向TC注册分支事务(向TC提供RM自身的身份信息),将其纳入XID对应全局事务的管辖;
- TM向TC发起针对 XID的全局提交或回滚决议;
- TC调度XID下管辖的全部分支事务完成提交或回滚请求。
我(TC)来讲,他(TM)来管,大家(RM)来听
3. 怎么玩
本地事务:@Transactional,Spring提供的
全局事务:@GlobalTransactional,SpringCloudAlibaba提供的
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?