天天看点

Seata - 基本介绍

Seata 是什么?

Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务。主要解决的就是在分布式系统中全局事务的一致性。

分布式事务产生的原因:一次业务操作需要跨多个数据源或需要跨多个系统进行远程调用,就会产生分布式事务问题。

如下例子:

用户购买商品的业务逻辑。整个业务逻辑由3个微服务提供支持:

  • 仓储服务:对给定的商品扣除仓储数量。
  • 订单服务:根据采购需求创建订单。
  • 帐户服务:从用户帐户中扣除余额。

架构图

Seata - 基本介绍

在上述事例中,单体应用被拆分成为服务应用,原来的三个模块被拆分成三个独立的应用,而三个独立的应用使用三个数据源,一次业务需要调用三个服务来完成。此时每个为服务的数据一致性由本地事务来保证,但是全局上的数据一致性问题没法保证,这就是典型的分布式事务问题。而Seata就是为解决这个问题而产生的。

Seata术语

TC - 事务协调者

维护全局和分支事务的状态,驱动全局事务提交或回滚。

TM - 事务管理器

定义全局事务的范围:开始全局事务、提交或回滚全局事务。

RM - 资源管理器

管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。

对应关系如下所示:

Seata - 基本介绍

使用过程中的执行流程如下:

  • TM向TC申请开启一个全局事务,全局事务创建成功之后会生成一个全局唯一的XID,XID在微服务调用链路的上下文中传递
  • RM向TC注册分支事务,将其纳入XID对应全局事务的管辖内
  • TM根据RM事务的成功与否,向TC发起全局事务的提交或回滚
  • TC调度XID下管辖的全部分支事务的提交和回滚