Seata 分布式事务控制

2024-09-04 23:12
文章标签 分布式 控制 事务 seata

本文主要是介绍Seata 分布式事务控制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

        Seata 是阿里巴巴和蚂蚁集团内部开发了分布式事务中间件,用于解决电商、支付、物流等业务场景中应用数据的一致性问题,2023 年 10 月,为了更好的通过社区驱动技术的演进,阿里和蚂蚁集团正式将 Seata 捐赠给 Apache 基金会。

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

一. Seata 核心组件

1. TC 事务协调器

TC (Transaction Coordinator) 维护全局和分支事务的状态,驱动全局事务提交或回滚。

2. TM 事务管理器

TM (Transaction Manager) 定义全局事务的范围:开始全局事务、提交或回滚全局事务。

3. RM 资源管理器

RM (Resource Manager) 管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。

二. Seata 事务模式

1. Seata 定义了全局事务的框架,全局事务定义为若干分支事务 的整体协调:

  1. TM 向 TC 请求发起(Begin)、提交(Commit)、回滚(Rollback)全局事务
  2. TM 把代表全局事务的 XID 绑定到分支事务上
  3. RM 向 TC 注册,把分支事务关联到 XID 代表的全局事务中
  4. RM 把分支事务的执行结果上报给 TC(可选)
  5. TC 发送分支提交(Branch Commit)或分支回滚(Branch Rollback)命令给 RM

2. Seata 的 全局事务 处理过程,分为两个阶段

  • 执行阶段 :
    • 执行分支事务,并保证执行结果满足是可回滚的(Rollbackable) 和 持久化的(Durable)。
  • 完成阶段:
    • 根据执行阶段结果形成的决议,应用通过 TM 发出的全局提交或回滚的请求给 TC, TC 命令 RM 驱动 分支事务进行 Commit 或 Rollback。

3. Seata 所谓事务模式是指

  • 运行在 Seata 全局事务框架下的 分支事务 的行为模式。准确地讲,应该叫作 分支事务模式。不同的 事务模式 区别在于 分支事务 使用不同的方式达到全局事务两个阶段的目标。即,回答以下两个问题:执行阶段 :如何执行并 保证 执行结果满足是 可回滚的(Rollbackable) 和 持久化的(Durable)。完成阶段:收到 TC 的命令后,做到事务的回滚/提交

三. Seata 四种事务模式

1. AT 模式:

        这是一种无侵入的分布式事务解决方案。用户只需关注自己的业务 SQL,Seata 框架会自动生成事务的二阶段提交和回滚操作。在一阶段,Seata 会拦截业务 SQL,解析 SQL 语义,找到要更新的业务数据,并保存快照数据和行锁。二阶段如果是提交,Seata 只需清理数据;如果是回滚,则用快照数据还原业务数据 。

使用场景:

  • 原理 :基于二阶段提交协议(2PC)的变种,通过记录数据的全局锁、前镜像和后镜像来实现分布式事务。
  • 第一阶段:是本地事务的执行和准备提交,记录数据快照;
  • 第二阶段:是根据一阶段的结果来决定是提交还是回滚。AT模式避免了全局锁和阻塞的问题,从而提高了系统的并发性能。
  • 在AT模式中:参与者的本地事务执行成功后即可提交,而不需要等待其他参与者的状态。AT模式需要配合数据库的undo_log数据表一起实现。

适用场景:适用于对数据一致性要求较高,且业务操作可以容忍一定延迟的场景。
主要区别:代码侵入性低,实现复杂度相对较低,性能优于XA模式,主要用于替代XA模式的场景。
启用配置:

  • 添加配置:seata:data-source-proxy-mode: AT
  • 在需要分布式事务的业务代码上添加注解@GlobalTransactional

2. TCC 模式:

        TCC(Try-Confirm-Cancel)模式需要用户根据自己的业务场景实现 Try、Confirm 和 Cancel 三个操作。Try 阶段是资源的检测和预留;Confirm 阶段执行业务操作提交;Cancel 阶段是预留资源释放 。

主要原理

  • 基于补偿事务的思想,分为三个操作阶段:尝试(Try)、确认(Confirm)、取消(Cancel)。每个业务操作都需要实现这三个操作,以确保分布式事务的最终一致性。

适用场景:

  • 适用于业务逻辑较为复杂,要求较高的业务处理流程。需要开发者针对每个业务操作,明确实现Try、Confirm和Cancel三个方法;还需要需要考虑Confirm和Cancel的失败情况下做好幂等处理。

主要区别:

  • 相较于AT模式,TCC模式对业务侵入性更高,需要开发者明确定义补偿逻辑,但它提供了更高的灵活性和性能。

3. Saga 模式:

        Saga 模式适用于长事务,由事件驱动,各个参与者之间异步执行。如果任何一个正向操作执行失败,Saga 模式会执行前面各参与者的逆向回滚操作,回滚已提交的参与者,使分布式事务回到初始状态 。

主要原理:

  • 通过长事务来维护各个微服务之间的数据一致性。Saga 分为多个子事务,每个子事务执行完成后都会发布事件,触发下一个子事务,如果某个子事务失败,则执行补偿操作以回滚之前的操作。
  • Saga模式的执行过程如下:
    • 执行正向操作:按照事务的逻辑顺序,依次执行正向操作。每个正向操作都会记录事务的执行状态。如果所有的正向操作都成功执行,则事务提交完成。如果某个正向操作失败,将会触发相应的补偿操作。补偿操作会撤销或修复正向操作的影响。
    • 执行补偿操作:按照逆序依次执行已经触发的补偿操作。补偿操作应该具备幂等性,以便可以多次执行而不会造成副作用。如果所有的补偿操作都成功执行,则事务回滚完成。如果补偿操作也失败,需要人工介入或其他手段来解决事务的一致性问题。

适用场景:

  • 适用于长事务场景,特别是那些无法使用TCC或AT模式的场景。

主要区别:

  • Saga 模式通过定义一系列的本地事务和补偿操作来保证整体事务的一致性,适合于长事务处理。与TCC相比,Saga模式可能会有更长的事务持续时间,但对业务的侵入性较小。

4. XA 模式:

        XA 模式是 Seata 支持的另一种分布式事务解决方案,它利用事务资源对 XA 协议的支持,以 XA 协议的机制来管理分支事务。XA 模式是两阶段提交协议,通过资源管理器和事务协调者来保证事务的原子性。

主要原理:

  • 基于XA接口的分布式事务实现,遵循两阶段提交协议。XA模式通过资源管理器(RM)、事务管理器(TM)和应用程序(AP)三者的协作,完成分布式事务的管理。从编程模型上,XA 模式与 AT 模式保持完全一致。只需要修改数据源代理,即可实现 XA 模式与 AT 模式之间的切换。

适用场景:

  • 适用于需要严格遵守ACID原则的分布式事务管理场景。

主要区别

  • XA是一种较为传统的解决方案,支持严格的ACID事务,但性能较低,资源消耗较大。

代码配置:

  • 添加配置 seata:data-source-proxy-mode: XA
  • 在需要分布式事务的业务代码上添加注解 @GlobalTransactional

Seata 官方文档

参考文章

这篇关于Seata 分布式事务控制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137301

相关文章

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

Golang使用etcd构建分布式锁的示例分享

《Golang使用etcd构建分布式锁的示例分享》在本教程中,我们将学习如何使用Go和etcd构建分布式锁系统,分布式锁系统对于管理对分布式系统中共享资源的并发访问至关重要,它有助于维护一致性,防止竞... 目录引言环境准备新建Go项目实现加锁和解锁功能测试分布式锁重构实现失败重试总结引言我们将使用Go作

Redis分布式锁使用及说明

《Redis分布式锁使用及说明》本文总结了Redis和Zookeeper在高可用性和高一致性场景下的应用,并详细介绍了Redis的分布式锁实现方式,包括使用Lua脚本和续期机制,最后,提到了RedLo... 目录Redis分布式锁加锁方式怎么会解错锁?举个小案例吧解锁方式续期总结Redis分布式锁如果追求

SpringBoot嵌套事务详解及失效解决方案

《SpringBoot嵌套事务详解及失效解决方案》在复杂的业务场景中,嵌套事务可以帮助我们更加精细地控制数据的一致性,然而,在SpringBoot中,如果嵌套事务的配置不当,可能会导致事务不生效的问题... 目录什么是嵌套事务?嵌套事务失效的原因核心问题:嵌套事务的解决方案方案一:将嵌套事务方法提取到独立类

Python实现局域网远程控制电脑

《Python实现局域网远程控制电脑》这篇文章主要为大家详细介绍了如何利用Python编写一个工具,可以实现远程控制局域网电脑关机,重启,注销等功能,感兴趣的小伙伴可以参考一下... 目录1.简介2. 运行效果3. 1.0版本相关源码服务端server.py客户端client.py4. 2.0版本相关源码1

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

集中式版本控制与分布式版本控制——Git 学习笔记01

什么是版本控制 如果你用 Microsoft Word 写过东西,那你八成会有这样的经历: 想删除一段文字,又怕将来这段文字有用,怎么办呢?有一个办法,先把当前文件“另存为”一个文件,然后继续改,改到某个程度,再“另存为”一个文件。就这样改着、存着……最后你的 Word 文档变成了这样: 过了几天,你想找回被删除的文字,但是已经记不清保存在哪个文件了,只能挨个去找。真麻烦,眼睛都花了。看

MySql 事务练习

事务(transaction) -- 事务 transaction-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求-- 事务的操作要么同时成功,要么同时失败-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账-- 逻辑:A给B转账1000:1.查询

开源分布式数据库中间件

转自:https://www.csdn.net/article/2015-07-16/2825228 MyCat:开源分布式数据库中间件 为什么需要MyCat? 虽然云计算时代,传统数据库存在着先天性的弊端,但是NoSQL数据库又无法将其替代。如果传统数据易于扩展,可切分,就可以避免单机(单库)的性能缺陷。 MyCat的目标就是:低成本地将现有的单机数据库和应用平滑迁移到“云”端