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提供的

浙公网安备 33010602011771号