Seata简介
Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务
组成
Seata是由一ID+三组件组成的
Transaction ID
全局唯一的事务ID
TC (Transaction Coordinator) - 事务协调者
维护全局和分支事务的状态,驱动全局事务提交或回滚。
seata server就是TC
TM (Transaction Manager) - 事务管理器
定义全局事务的范围:开始全局事务、提交或回滚全局事务。
事务的发起方,使用注解@GlobalTransactional
RM (Resource Manager) - 资源管理器
管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。
事务的参与者
处理过程
- TM向TC申请开启一个全局事务,全局事务创建成功并生成一个全局唯一性的XID
- XID在微服务调用链路的上下文中传播
- RM向TC注册分支事务,将其纳入XID对应的全局事务的管辖
- TM向TC发起针对XID的全局提交或回滚协议
- TC调度XID下管辖的全部分支事务完成提交或回滚请求