mysql xa测试方案_mysql xa导致的事务一直running问题

背景描述

使用xa进行测试时,对mysql进行了一些xa各阶段锁定试验,后来出现卡死情况就杀掉了线程,重启了mysql服务。重启后发现插入、修改数据都正常,但无法修改表结构,修改表结构就处于卡死状态,过一分多钟报超时错误。多次重启mysql服务后,问题依然如故.

现象

查询innodb_trx表,发现有两个事务处于运行中。

SELECT * from information_schema.INNODB_TRX;

EvYjmq.jpg 图片发自简书App

尝试解决

方案1–杀进程—行不通

网上资料都是说按照trx_mysql_thread_id找到对应进程杀掉,但我这里是0,没有进程id,没法杀,而且它是重启mysql服务后自动就运行的两个事务。这个方案的本质是要找到事务的发起者,然后通过发起者停掉事务,但我们这个问题中事务发起者未知。

2.方案2–xa rollback–不起作用

还有资料说,通过xa recover查看当前xa事务,然后回滚或提交。

UjiEfi.png image.png

我们根据xid进行事务的回滚或者提交,提示成功了。

xa ROLLBACK 'globalid','branch-2';

xa ROLLBACK 'globalid','branch-1';

2e2A7j.png image.png

我们在通过

xa recover查询发现确实没有xa事务了

UJJNve.png image.png

是不是问题解决了呢?我们在看一下innodb_trx发现事务仍然存在,不能解决。

Z7BZRj.png image.png

针对上面的xa rollback我们也可以尝试用xa commit,问题一样不能解决(需要再次重启mysql才能运行,否则会找不到对应的xid)。

xa COMMIT 'globalid','branch-2';

xa COMMIT 'globalid','branch-1';

ZrURFj.png image.png

问题分析

通过重启mysql后事务依然存在,我们大概推断应该跟redo undo有关系,xa事务异常后,mysql服务重启检测到了这两个事务就自动运行了,但因为未知原因,这两个事务并没有执行,一直处于running状态。

曾经试图研究mysql的redo undo机制或者对应的文件格式,但时间关系没有深入。

尝试能否打开对应的redo文件,对里面的语句进行修改,但网上找了资料没有合适的工具可以做这个事情。

一直很苦恼的思索解决办法,也咨询身边的一些朋友,对没有遇到过这方面的问题。

可行的解决方案

今天灵机一动,奔着大不了重新安装mysql的心态进行了破坏性的探索,当然前提要提前把数据备份出来。尝试停止mysql服务后,将mysql对应的datadir目录下几个文件删除掉,对应文件见下图。

Q36nem.png image.png

然后重启mysql服务,曾担心启动失败的,但没想到mysql顺利的启动成功了,然后查看对应的表,发现一只running的事务终于消息了。

jEjmu2.png image.png

世界终于回归美好了,一片幸福感洋溢在温馨的大地上。

后续有时间我会继续深入分析其中的原理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL XA事务是一种分布式事务处理方式,它允许多个独立的事务同时访问多个数据库,并将它们作为一个全局事务进行处理,从而保证了数据的一致性和完整性。 在MySQL 5.7中,XA事务的实现基于两个重要的组件:XA接口和InnoDB存储引擎。XA接口提供了一组标准API,使得应用程序可以以统一的方式与分布式事务协调器进行通信,而InnoDB存储引擎则提供了具体的XA事务实现。 要使用MySQL XA事务,需要确保以下几点: 1. 数据库支持XA协议,如MySQL 5.7及以上版本。 2. 数据库引擎支持XA事务,如InnoDB存储引擎。 3. 应用程序使用XA接口与协调器进行通信。 4. 执行XA事务的数据库必须在同一个XA事务中注册。 在使用MySQL XA事务时,需要对事务进行以下基本操作: 1. 准备(prepare):在分布式事务中,每个数据库都会先执行准备操作,以确保所有数据库都可以成功执行事务。 2. 提交(commit):当所有数据库都准备好时,可以执行提交操作,将分布式事务提交到所有数据库。 3. 回滚(rollback):如果任意一个数据库无法完成准备或提交操作,则需要执行回滚操作,以确保所有数据库都回到事务开始前的状态。 总的来说,MySQL XA事务是一种非常强大的分布式事务处理方式,可以实现多个独立的事务同时访问多个数据库,并将它们作为一个全局事务进行处理,从而保证了数据的一致性和完整性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值