Seata

seata中文使用文档

概念

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

由一ID+三组件实现

一ID

  • Transaction ID XID 全局唯一

三组件

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

整体流程

  1. TM向TC申请开启一个全局事务,全局事务创建成功并生成一个全局唯一的XID
  2. XID在微服务调用链路上下文中传播
  3. RM向TC注册分支事务,将其纳入XID对应全局事务的管辖
  4. TM向TC发起针对XID的全局提交或者回滚决议
  5. TC调度XID下管辖的全部分支事务完成提交或者回滚请求
相关推荐
天空'之城3 分钟前
Linux 系统编程 10:线程同步
linux·开发语言·系统编程·线程同步
Vect__5 分钟前
Go 数据结构 slice 深度剖析
开发语言·数据结构·golang
想你依然心痛7 分钟前
AtomCode在Python数据科学项目中的使用体验:从数据分析到可视化
开发语言·python·数据分析
我是个假程序员8 分钟前
实例化动作脚本类,并执行,执行类似N_F1_SAVE.java这种
java·nc
满天星83035779 分钟前
【Qt】控件(二) (geometry及与frameGeometry的区别)
开发语言·qt
青山木19 分钟前
Hot 100 --- LRU 缓存
java·数据结构·算法·leetcode·链表·缓存·哈希
花生了什么事o21 分钟前
Java 线程池:从参数到拒绝策略
java·jvm
冰暮流星23 分钟前
flask之app.py讲解
后端·python·flask
Esaka_Forever30 分钟前
Python 与 JS (V8) 垃圾回收核心区别 + 底层根源分析
开发语言·javascript·jvm
长孙豪翔32 分钟前
引发事件的问题
java·linux·数据库