分布式事务协调器Seata

Seata 是什么? | Apache Seata

1、四种模式的选择

1.1 只有AT、 XA模式是代码无侵入的。首选这两个。

1.2 XA模式

XA 是一种基于两阶段提交协议(2PC)的分布式事务协议,它由 X/Open 组织提出。在这种模式下,事务管理器(Transaction Manager, TM)需要与多个资源管理器(Resource Manager, RM)进行协调,以确保事务的原子性。

两阶段提交协议(2PC)的工作过程:

  • 第一阶段(准备阶段):事务管理器指示参与事务的所有资源管理器准备提交事务。每个资源管理器将对事务进行准备,如果可以提交事务,就将事务数据写入日志文件并向事务管理器返回一个“准备好”响应。
  • 第二阶段(提交/回滚阶段):如果所有资源管理器都报告准备好,则事务管理器指示它们提交事务。如果任何资源管理器不能提交事务,则事务管理器指示所有资源管理器回滚事务。

Seata XA 模式的实现使用了上述两阶段提交协议来确保分布式事务的原子性。在 Seata 中,TM 负责协调整个事务的提交或回滚,而 RM 则是分布式事务中各个数据库实例或其他事务资源。

Seata XA 模式的优点:

  • 一致性:通过使用 2PC 确保事务的强一致性。
  • 遵循标准:XA 协议是一个成熟的、经过广泛验证的分布式事务协议。

Seata XA 模式的缺点:

  • 性能成本:由于涉及多个阶段和网络往返,性能可能低于其他轻量级事务协议(如AT模式)。
  • 锁资源:在两阶段提交过程中,会在涉及的资源上持有锁,可能导致资源锁定时间较长。

使用场景:

Seata XA 模式适合于对数据一致性要求极高的场景,以及对性能要求不是非常敏感的环境。由于它提供了强一致性保证,因此常用于金融、支付等领域的应用。

1.3 AT模式

Seata AT模式(Automatic Transaction Mode)是Seata提供的一种创新的分布式事务解决方案,它不同于传统的XA模式。AT模式旨在通过一种轻量级的方式,提供高性能且易于使用的分布式事务能力。AT模式主要针对关系型数据库的分布式事务处理。

AT模式的工作原理:

AT模式通过以下三个核心组件来管理分布式事务的生命周期:

  1. 事务协调器(TC,Transaction Coordinator): TC是分布式事务的协调者,负责维护全局事务的状态,并驱动全局事务的提交或回滚。

  2. 事务管理器(TM,Transaction Manager): TM负责定义事务的范围,即开始和结束全局事务的边界,它会在适当的时机向TC注册并报告全局事务的状态。

  3. 资源管理器(RM,Resource Manager): RM负责管理分布式事务中涉及的资源,通常是数据库连接。它将具体的数据库操作与TC进行通信,并接受TC的指令来提交或回滚分支事务。

AT模式的事务处理过程:

AT模式通过以下步骤来处理事务:

  1. 开始全局事务: 当应用需要执行分布式事务时,TM向TC发起一个新的全局事务,并获得一个全局事务ID(XID)。

  2. 业务执行: 在执行业务操作时,每个数据库操作都被看作是全局事务的一个分支。RM负责拦截数据操作请求,并执行两件事情:一是在本地数据库中执行实际的SQL操作;二是记录数据操作前后的状态差异,称为before imageafter image,用于后续的事务提交或回滚。

  3. 请求事务提交: 业务执行完毕后,TM会向TC请求提交全局事务。

  4. TC驱动二阶段提交/回滚: 在第一阶段,TC会询问所有参与当前全局事务的RM是否准备好提交事务。如果所有RM都报告准备就绪,TC将进入第二阶段,指示所有RM提交分支事务。 如果任何一个RM报告准备失败,或者业务逻辑中发生异常导致TM请求回滚全局事务,TC则会指示所有RM回滚分支事务。

  5. 事务回滚处理: 如果分支事务需要回滚,RM会使用记录的before image来撤销之前的操作,确保数据的一致性。

AT模式的优点:

  • 高性能:与XA模式相比,AT模式不需要两阶段锁定资源,因此可以减少锁的竞争,提高性能。
  • 简单易用:AT模式对开发者更加友好,避免了XA中复杂的API和协议。

AT模式的缺点:

  • 资源占用:由于需要记录数据修改的前后镜像,会增加存储的消耗。
  • 数据一致性:在某些极端情况下,例如服务宕机或网络分区,可能会暂时出现数据不一致的情况。

AT模式适用于需要处理高并发事务,且对一致性要求不是极端严格的分布式系统。它能够很好地平衡分布式事务的性能和一致性需求。在实际部署Seata和使用AT模式之前,建议对Seata的架构和工作机制有一个深入的理解,并进行充分的测试以确保它适合你。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/760754.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UGUI界面性能优化1-UGUI开发界面时常见的优化方法和注意事项

UGUI是Unity引擎中的一套用户界面系统,用于开发游戏和应用程序的UI界面。在进行UGUI开发时,可以采取以下优化方法和注意事项: 使用UI对象池:在频繁创建和销毁UI对象时,可以使用对象池来重复利用已创建的UI对象&#xf…

MySQL数据库索引介绍

前言 在数据库中创建索引可以提高数据检索的速度和效率。索引是一种数据结构,类似于书籍的目录,它可以帮助数据库系统快速定位和访问表中的特定数据行。 目录 一、索引相关介绍 1. 概述 2. 作用 3. 副作用 4. 创建原则依据 二、索引的分类与管理…

ChatGPT:智能论文写作指南,让您成为写作高手

ChatGPT无限次数:点击直达 写作是学术研究中不可或缺的一环,然而,对于许多人来说,写作往往是一项艰巨而费时的任务。但是,现在有了ChatGPT,您将能够以前所未有的速度和准确性编写高质量的论文。本文将向您介绍如何利用…

Vue2(七):脚手架、render函数、ref属性、props配置项、mixin(混入)、插件、scoped样式

一、脚手架结构(Vue CLI) ├── node_modules ├── public │ ├── favicon.ico: 页签图标 │ └── index.html: 主页面 ├── src │ ├── assets: 存放静态资源 │ │ └── logo.png │ │── component: 存放组件 │ │ …

详解main函数参数argc、argv及如何传参

目录 1、main()函数参数 2、main函数如何传参 2.1 环境准备 2.2 通过 Powershell 窗口传参 2.3 通过vs界面传参 3、int main() 和 int main(int argc, char *argv[]) 特点 1、main()函数参数 在C语言中,main函数可以带参数。main函数的原型通常为以下两种形式…

基于Springboot+Vue的在线考试系统

项目介绍 这是一个在线考试系统,使用Maven进行项目管理,基于springbootmybatis框架开发的项目,mysql底层数据库,前端采用VueElementPlus,作为初学springbootvue前后端分离架构的同学是一个很不错的项目,如…

Diff算法详解

简要了解 Diff 算法目的就是找出新旧虚拟dom差异,最小化更新视图;即本质就是比较两个JS对象的差异;并不是页面上所有的更新都需要Diff算法。 在了解Diff算法之前,我们首先需要了解一下什么是虚拟DOM。 虚拟DOM 虚拟DOM是表示真实…

C++初阶:vector相关练习

目录 1. 只出现一次的数2. 杨辉三角3. 删除有序数组中的重复项4. 只出现一次的数II5. 只出现一次的数III6. 数组中出现次数超过一半的数7. 电话号码的字母组合(多叉树遍历) 1. 只出现一次的数 题目信息: 题目链接: 只出现一次的数…

集合系列(六) -IdentityHashMap详解

一、摘要 在集合系列的第一章,咱们了解到,Map 的实现类有 HashMap、LinkedHashMap、TreeMap、IdentityHashMap、WeakHashMap、Hashtable、Properties等等。 应该有很多人不知道 IdentityHashMap 的存在,其中不乏工作很多年的 Java 开发者&am…

22.CP AUTOSAR PostBuild怎么用(2)

目录 1.引入 2. Post-Build Loadable集成要点 3.SWC上的变体管理 1.引入 在前一篇,我们分别讲了AUTSAR对于配置数据编译时间的设计,如下: Pre-CompileTime:在这个阶段配置参数参与编译后就无法再改变了,常见的如宏定义,该方式可以有效缩减代码量,节省Flash空间。生成…

python英文缩写单词扩写

词典 # 缩略词-扩展字典 contractions {"cant": "cannot","wont": "will not","Im": "I am","yours":"your"# 添加更多的缩略词及其扩展形式 }# 扩展缩略词的函数 def expand_contractions…

网文遇冷、短剧续命,阅文去年营收下滑8%

阅文能否靠短剧“续命”? 3月18日,阅文集团(下称“阅文”,00772.HK)公布了2023年财报,尽管去年净利润增加三成以上,但其营收持续下滑。 「不二研究」据其最新年报发现:2023年,阅文营收同比下滑8.0%。目前…

数组实现对数组中对象中的指定项的查找并输出该条记录

文章目录 需求分析 需求 已知返回的数据如下:,现需找到指定字段的那一项并输出 分析 写一个方法就能搞定,代码中定义了一个名为 findDeviceByName 的函数,它会遍历给定的数组,查找其中 deviceName 字段值等于目标…

C语言数据在内存中的存续:一篇文章让你秒懂基础!

JAMES别扣了-CSDN博客 💕在校大学生一枚。对IT有着极其浓厚的兴趣 ✨系列专栏目前为C语言初阶、后续会更新c语言的学习方法以及c题目分享. 😍希望我的文章对大家有着不一样的帮助,欢迎大家关注我,我也会回关,大家一起交…

关于javascript数字精度丢失的解决办法

分析原因 众所周知,在JavaScript中计算两个十进制数的和,有时候会出现令人惊讶的结果,主要原因是计算机将数据存储为二进制所引起的,所以这并不是javascript存在的缺陷,而在其他语言中也有类似的问题。 例如下面的例子…

aac可以直接改成mp3吗?快速转换的3个方法~

AAC(Advanced Audio Coding)文件格式的诞生源于对音频压缩技术的不断追求。由Fraunhofer IIS、杜比实验室、AT&T、索尼等联合开发,旨在提供更高质量的音频压缩效果。AAC文件格式因其出色的音质和高效的压缩算法,成为数字音频领…

使用SourceTree获取git代码

1、在浏览器打开git的地址,并且使用用户名和密码登录; 2、输入你的git账号密码; 3、打开SourceTree,地址是自动带过来的,点击第二个“浏览”选择你在D盘或其它盘自己创建的文件夹; 4、正在拉代码&#…

智慧商显安卓主板MT8788_联发科MTK平台多媒体广告一体机方案

MT8788高性能智能主板,支持Android 9.0操作系统,支持双屏异显功能;MT8788是基于12nm工艺制程四核A73四核A53架构的八核心CPU,主频高达2.0GHz,拥有超强的通用计算性能。 MT8788主板采用10层二阶超高密度PCB板,集成了4G、百兆以太网、2.4G/5G 双频WiFi、蓝…

javaSwing扫雷

一、介绍 1.1 背景 在1964年 有一个叫“方 块”的游戏,这是扫雷最原始的版本。后来,这个游戏被改成了另一种游戏,叫做“Rlogic”。在这个游戏中,玩家扮演了一名军队的军人,接受了一项艰难的任务:为指挥中…

记录一次服务器内存使用率过高达到90%告警问题排查。

目录 一、前言二、问题排查处理三、 结尾 👩🏽‍💻个人主页:阿木木AEcru 🔥 系列专栏:Docker容器化部署系列 💹每一次技术突破,都是对自我能力的挑战和超越。 一、前言 一大早就有一…