Seata 的3个基本组成部分
事务协调器(TC):维护全局事务和分支事务的状态,驱动全局提交或回滚。
事务管理器(TM):用于开启全局事务、提交或者回滚全局事务,是全局事务的开启者。
资源管理器(RM):用于分支事务上的资源管理,向TC注册分支事务,上报分支事务的状态,接受TC的命令来提交或者回滚分支事务。
Seata管理的分布式事务的典型生命周期
- TM向TC请求发起一个全局事务,TC返回一个代表这个全局事务的XID。
- XID通过微服务的调用链传播。
- 每个RM拿到XID后向TC发起一个分支事务,TC返回一个代表这个分支事务的XID。
- RM完成本地分支的业务,提交本地分支,并且报告给TC。
- 局事务调用链处理完毕,TM根据有无异常向TC发起全局事务的提交或者回滚。
- 假设某个RM本地事务失败。该RM自身驱动本地事务回滚,并且报告给TC。
- TM检测到了某个分支事务失败,向TC发起全局事务回滚。
- TC给每一个RM发送消息,通知它们全部回滚。
- TC将全局事务回滚的结果发送给TM,全局事务结束。