Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务。Seata 将为用户提供了 AT、TCC、SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案。

分布式事务处理过程

1个ID+3个组件

transaction ID – XID

全局唯一的事务ID

3个组件

  • TC (Transaction Coordinator) - 事务协调者:维护全局和分支事务的状态,驱动全局事务提交或回滚。
  • TM (Transaction Manager) - 事务管理器:定义全局事务的范围:开始全局事务、提交或回滚全局事务。
  • RM (Resource Manager) - 资源管理器:管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。

处理过程

  • TM 向 TC 申请开启一个全局事务,全局事务创建成功并生成一个全局唯一的 XID ;

  • XID 在微服务调用链路的上下文中传播;

  • RM 向 TC 注册分支事务,将其纳入 XID 对应全局事务的管辖;

  • TM 向 TC 发起针对 XID 的全局提交或回滚决议;

  • TC 调度 XID 下管辖的全部分支事务完成提交或回滚。

下载中心

https://seata.io/zh-cn/blog/download.html

框架用法

将 `@GlobalTransactional` 注解,加入业务方法上即可。

安装

修改配置

修改为数据库模式,来存储事务日志。

  • 找到 `conf/file.conf` 文件,将 `store.mode` 改为 `db` ;

  • 找到 `db ` 标签,更改为对应的数据库链接信息;

  • 下载脚本,找到对应数据库建表脚本,并执行。

修改 nacos 为注册中心。

  • 找到 `conf/registry.conf` ,将 `registry.type` 改为 `nacos` ;

  • 找到 `nacos ` 标签,更改为对应的 Nacos 信息。

运行

由于我们修改注册中心为 nacos ,需先启动 nacos。

然后找到 `bin` 目录,选择合适的脚本运行服务。