0%

Seata简介

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下管辖的全部分支事务完成提交或回滚请求