Seata 学习笔记

Seata 概述

Seata 是 Simple Extensible Autonomous Transaction Architecture(简单可扩展的自主事务体系结构) 的简写,由 feascar 改名而来。Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务。Seata 将为用户提供了 AT、TCC、SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案。主要方式是 AT。

Seata的架构中,一共有三个角色

1、TC (Transaction Coordinator) - 事务协调者

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

2、TM (Transaction Manager) - 事务管理器

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

3、RM (Resource Manager) - 资源管理器

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

Seata 如何处理呢分布式事务

Business 是业务入口,在程序中会通过注解来说明他是一个全局事务,这时他的角色为 TM(事务管理者)。

Business 会请求 TC(事务协调器,一个独立运行的服务),说明自己要开启一个全局事务,TC 会生成一个全局事务ID(XID),并返回给 Business。

Business 得到 XID 后,开始调用微服务,例如调用 Storage。

Storage 会收到 XID,知道自己的事务属于这个全局事务。Storage 执行自己的业务逻辑,操作本地数据库。

Storage 会把自己的事务注册到 TC,作为这个 XID 下面的一个分支事务,并且把自己的事务执行结果也告诉 TC。

此时 Storage 的角色是 RM(资源管理者),资源是指本地数据库。

Order、Account 的执行逻辑与 Storage 一致。

在各个微服务都执行完成后,TC 可以知道 XID 下各个分支事务的执行结果,TM(Business) 也就知道了。

Business 如果发现各个微服务的本地事务都执行成功了,就请求 TC 对这个 XID 提交,否则回滚。

TC 收到请求后,向 XID 下的所有分支事务发起相应请求。

各个微服务收到 TC 的请求后,执行相应指令,并把执行结果上报 TC。

具体工作过程

TM 请求 TC,开始一个新的全局事务,TC 会为这个全局事务生成一个 XID。

XID 通过微服务的调用链传递到其他微服务。

RM 把本地事务作为这个XID的分支事务注册到TC。

TM 请求 TC 对这个 XID 进行提交或回滚。

TC 指挥这个 XID 下面的所有分支事务进行提交、回滚。

 详细工作流程示例

下面我们通过一个分支事务的执行过程来了解 Seata 的工作流程。

例如有一个业务表 product(id,name),分支事务的业务逻辑:

  • update product set name = 'GTS' where name = 'TXC';
        一阶段

(1)解析 SQL 得到 SQL 的类型(UPDATE),表(product),条件(where name = 'TXC')等相关的信息。

(2)查询前镜像 根据解析得到的条件信息,生成查询语句,定位数据。

select id, name from product where name = 'TXC';

得到前镜像:

(3)执行业务 SQL

执行自己的业务逻辑:

update product set name = 'GTS' where name = 'TXC';

把 name 改为了 GTS。

(4)查询后镜像

根据前镜像的结果,通过 主键 定位数据。

select id, name from product where id = 1;

得到后镜像:

(5)插入回滚日志把前后镜像数据以及业务 SQL 相关的信息组成一条回滚日志记录,插入到 UNDO_LOG 表中。

(6)提交前,向 TC 注册分支:申请 product 表中,主键值等于 1 的记录的 全局锁 。

(7)本地事务提交:业务数据的更新和前面步骤中生成的 UNDO LOG 一并提交。

(8)将本地事务提交的结果上报给 TC。

二阶段 - 回滚

(1)收到 TC 的分支回滚请求,开启一个本地事务,执行如下操作。

(2)通过 XID 和 Branch ID 查找到相应的 UNDO LOG 记录。

(3)数据校验 拿 UNDO LOG 中的后镜与当前数据进行比较,根据校验结果决定是否做回滚。

(4)根据 UNDO LOG 中的前镜像和业务 SQL 的相关信息生成并执行回滚的语句:

update product set name = 'TXC' where id = 1;

(5)提交本地事务 并把本地事务的执行结果(即分支事务回滚的结果)上报给 TC。

二阶段 - 提交

(1)收到 TC 的分支提交请求,把请求放入一个异步任务的队列中,马上返回提交成功的结果给 TC。

(2)异步任务阶段的分支提交请求,将异步和批量地删除相应 UNDO LOG 记录。

官网连接:

Seata 是什么? | Seata

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值