当前位置: 首页 > news >正文

【分布式事务 XA模式】MySQL XA模式详解

MYSQL中的XA事务

  • 写在前面
  • 1. XA事务的基本原理
  • 2. MySQL XA事务操作

写在前面

MySQL 的 5.0.3 版本开始支持XA分布式事务,并且只有innoDB存储引擎支持XA事务。

1. XA事务的基本原理

XA事务本质上是一种基于两阶段提交的分布式事务,分布式事务可以理解成多个数据库事务共同完成一个原子性的事务操作。参与操作的多个事务要么全部提交成功,要么全部提交失败。

XA事务支持不同数据库之间实现分布式事务。这里的不同数据库,可以是不通的MySQL实力,也可以是不同的数据库类型,比如MySQL数据库和sqlite数据库或者是oracle数据库。

XA事务由一个事务管理器、一个或者多个资源管理器和一个应用程序组成。

在这里插入图片描述

  • 事务管理器:主要对参与全局事务的各个分支事务进行协调,并与资源管理器进行通讯
  • 资源管理器:主要提供对事务资源的访问能力,可以把一个数据库看作一个资源管理器
  • 应用程序:主要用来明确全局事务和各个分支事务,指定全局事务中的各个操作

因为XA事务是基于两阶段提交的分布式事务,所以XA事务也被拆分为Prepare阶段和Commit阶段。

  1. 在Prepare阶段,事务管理器向资源管理器发送准备指令,资源管理器接受到指令后,执行数据的修改操作并记录相关日志信息,然后向事务管理器返回可以提交或者不可以提交的结果信息。

在这里插入图片描述

  1. 在Commit阶段,事务管理器接受所有资源管理器返回的结果信息,如果某一个或多个资源管理器向事务管理器返回的结果信息为不可以提交,或者超时,则事务管理器向所有资源管理器发送回滚指令。

在这里插入图片描述

  1. 如果事务管理器收到的所有资源管理器返回的结果信息为可以提交,则事务管理器向所有资源管理器发送提交事务的指令。

在这里插入图片描述

2. MySQL XA事务操作

  1. 开启XA事务,如果使用的是XA START命令而不是XA BEGIN命令,则不支持 JOIN 操作。xid 是一个唯一值,表示事务分支标识符。
XA {START|BEGIN} xid {JOIN}
  1. 提交一个XA事务,如果使用ONE PHASE命令,表示使用一阶段提交。在两阶段提交协议中,如果只有一个资源管理器参与操作,则可以优化为一阶段提交。
XA COMMIT xid [ONE PHASE]
  1. 结束一个XA事务
XA PREPARE xid
  1. 准备提交XA事务
XA PREPARE xid
  1. 回滚XA事务
XA ROLLBACK xid
  1. 列出所有处于准备阶段的XA事务
XA RECOVER [CONVERT XID]

MySQL XA 事务使用XID表示分布式事务,xid主要由以下几部分组成

xid: gtrib[, bqual [, formatID]]
  • gtrid:必须,为字符串,表示全局事务标识符。
  • bqual:可选,为字符串,默认为空串,表示分支限定符。
  • formatID:可选,默认值为1,用于标识gtrid和bqual值使用的格式。

相关文章:

  • 如何操作系统缓冲区减少了磁盘碎片化?
  • springboot-基础-添加model和controller的简单例子+常用注解含义
  • vscode不能远程连接ubuntu18.04.6
  • ElasticSearch之找到乔丹的空中大灌篮电影
  • Android 接入指纹识别
  • 【QT+QGIS跨平台编译】之五十四:【QGIS_CORE跨平台编译】—【qgssqlstatementlexer.cpp生成】
  • 【Linux】部署前后端分离项目---(Nginx自启,负载均衡)
  • SpringMVC(2)
  • 如何在 CentOS 上安装 ONLYOFFICE 文档 8.0
  • MySQL集群 双主架构(配置命令)
  • Nginx 和 Apache 的比较
  • Python 鼠标模拟
  • 【电子通识】为什么单片机芯片上会有多组VDD电源?
  • ES-ES的基本概念
  • CSS3技巧37:JS+CSS3 制作旋转图片墙
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • Android 控件背景颜色处理
  • angular组件开发
  • Docker入门(二) - Dockerfile
  • flutter的key在widget list的作用以及必要性
  • IE报vuex requires a Promise polyfill in this browser问题解决
  • JS学习笔记——闭包
  • macOS 中 shell 创建文件夹及文件并 VS Code 打开
  • OpenStack安装流程(juno版)- 添加网络服务(neutron)- controller节点
  • SegmentFault 技术周刊 Vol.27 - Git 学习宝典:程序员走江湖必备
  • vue 个人积累(使用工具,组件)
  • vuex 笔记整理
  • windows下如何用phpstorm同步测试服务器
  • 基于遗传算法的优化问题求解
  • 如何用纯 CSS 创作一个菱形 loader 动画
  • ​DB-Engines 11月数据库排名:PostgreSQL坐稳同期涨幅榜冠军宝座
  • ​iOS安全加固方法及实现
  • ###51单片机学习(1)-----单片机烧录软件的使用,以及如何建立一个工程项目
  • (2)(2.4) TerraRanger Tower/Tower EVO(360度)
  • (javascript)再说document.body.scrollTop的使用问题
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (附源码)python旅游推荐系统 毕业设计 250623
  • (附源码)springboot码头作业管理系统 毕业设计 341654
  • (附源码)ssm基于web技术的医务志愿者管理系统 毕业设计 100910
  • (论文阅读笔记)Network planning with deep reinforcement learning
  • (一) storm的集群安装与配置
  • .NET 中选择合适的文件打开模式(CreateNew, Create, Open, OpenOrCreate, Truncate, Append)
  • .NET多线程执行函数
  • .NET上SQLite的连接
  • .Net下使用 Geb.Video.FFMPEG 操作视频文件
  • @SentinelResource详解
  • @TableLogic注解说明,以及对增删改查的影响
  • [AX]AX2012开发新特性-禁止表或者表字段
  • [bzoj1912]异象石(set)
  • [CC-FNCS]Chef and Churu
  • [Codeforces] number theory (R1600) Part.11
  • [HDU3710]Battle over Cities
  • [hive] posexplode函数
  • [HTML API]HTMLCollection
  • [IE技巧] IE8中HTTP连接数目的变化