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下管辖的全部分支事务完成提交或者回滚请求
相关推荐
白宇横流学长1 天前
基于SpringBoot实现的历史馆藏系统设计与实现【源码+文档】
java·spring boot·后端
moxiaoran57531 天前
Go语言结构体
开发语言·后端·golang
wearegogog1231 天前
基于C# WinForm实现的带条码打印的固定资产管理
开发语言·c#
毕设源码-赖学姐1 天前
【开题答辩全过程】以 高校教学资源共享系统的设计与实现为例,包含答辩的问题和答案
java·eclipse
Lvan的前端笔记1 天前
python:深入理解 Python 的 `__name__ == “__main__“` 与双下划线(dunder)机制
开发语言·python
爱海贼的无处不在1 天前
现在还有Java面试者不会开发Starter组件
后端·面试·架构
辣机小司1 天前
【软件设计师】自编思维导图和学习资料分享(中级已过)
java·c++·软考·软件设计师
董世昌411 天前
什么是扩展运算符?有什么使用场景?
开发语言·前端·javascript
lsx2024061 天前
C++ 重载运算符和重载函数
开发语言
爱笑的眼睛111 天前
深入解析Matplotlib Axes API:构建复杂可视化架构的核心
java·人工智能·python·ai