如何在服务器崩溃后提交XA事务
问题描述:
我在Mint 18上使用MySQL 5.7.19-0ubuntu0.16.04.1。我发现当我准备好XA事务时,然后服务器崩溃了。服务重新启动后,我无法再触碰交易。它仍然锁定了桌子。如何在服务器崩溃后提交XA事务
mysql> xa start'1';
mysql> xa end'1';
mysq> xa准备'1';
须藤killall -9的mysqld
须藤服务启动mysqld
的MySQL> XA犯 '1';
ERROR 1399(XAE07):XAER_RMFAIL:当全局事务是在不存在的状态
的MySQL> XA启动 '1' 的命令不能被执行;
ERROR 1440(XAE08):XAER_DUPID:该XID已经存在
的情况与bug71352相似,但我的版本是那么的遥远。 我错过了什么?
答
我不能重现该问题:
mysql> \! lsb_release --description
Description: Linux Mint 18.2 Sonya
mysql> SELECT VERSION();
+-----------+
| VERSION() |
+-----------+
| 5.7.19 |
+-----------+
1 row in set (0.00 sec)
mysql> DROP TABLE IF EXISTS `t`;
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> CREATE TABLE IF NOT EXISTS `t` (
-> `id` INT
->) ENGINE=InnoDB;
Query OK, 0 rows affected (0.00 sec)
mysql> XA START '1';
Query OK, 0 rows affected (0.00 sec)
mysql> INSERT INTO `t`
-> VALUES (1);
Query OK, 1 row affected (0.01 sec)
mysql> XA END '1';
Query OK, 0 rows affected (0.00 sec)
mysql> XA PREPARE '1';
Query OK, 0 rows affected (0.00 sec)
mysql> XA RECOVER;
+----------+--------------+--------------+------+
| formatID | gtrid_length | bqual_length | data |
+----------+--------------+--------------+------+
| 1 | 1 | 0 | 1 |
+----------+--------------+--------------+------+
1 row in set (0.00 sec)
-- Killed mysqld from other session
mysql> \! service mysql status | grep 'Active'
Active: inactive (dead) since 33s ago
-- Restared mysqld from other session
mysql> \! service mysql status | grep 'Active'
Active: active (running) since 3s ago
mysql> XA RECOVER;
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id:
Current database:
+----------+--------------+--------------+------+
| formatID | gtrid_length | bqual_length | data |
+----------+--------------+--------------+------+
| 1 | 1 | 0 | 1 |
+----------+--------------+--------------+------+
1 row in set (0.02 sec)
mysql> SELECT `id` FROM `t`;
Empty set (0.00 sec)
mysql> XA START '1';
ERROR 1440 (XAE08): XAER_DUPID: The XID already exists
mysql> XA COMMIT '1';
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT `id` FROM `t`;
+------+
| id |
+------+
| 1 |
+------+
1 row in set (0.00 sec)
答
的XA开始一定会失败,这是预期的,这是悬而未决的XA事务。你需要先做一次xa恢复。