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
目录,选择合适的脚本运行服务。