Commit 67d89e4d authored by Marko Mäkelä's avatar Marko Mäkelä

MDEV-15143 InnoDB: Rollback of trx with id 0 completed

When InnoDB has completed the rollback of a recovered transaction,
it used to display the transaction identifier.

This was broken in MySQL 5.7.2 in
https://github.com/mysql/mysql-server/commit/2f5f3cd3ac46d46c7635e778b338f63b5521cd46
which was merged to MariaDB 10.2.2 in
commit 2e814d47.

trx_rollback_active(): Cache the transaction ID before it will be
reset by transaction commit. Do not display the message if the
rollback was interrupted by shutdown (MDEV-13797, MDEV-12352).
parent f5f56a07
...@@ -37,3 +37,4 @@ SELECT * FROM t; ...@@ -37,3 +37,4 @@ SELECT * FROM t;
a a
3 3
DROP TABLE t; DROP TABLE t;
FOUND 1 /Rolled back recovered transaction [^0]/ in mysqld.1.err
...@@ -41,3 +41,6 @@ SELECT * FROM t; ...@@ -41,3 +41,6 @@ SELECT * FROM t;
--source include/restart_mysqld.inc --source include/restart_mysqld.inc
SELECT * FROM t; SELECT * FROM t;
DROP TABLE t; DROP TABLE t;
let SEARCH_FILE= $MYSQLTEST_VARDIR/log/mysqld.1.err;
--let SEARCH_PATTERN= Rolled back recovered transaction [^0]
--source include/search_pattern_in_file.inc
...@@ -10,9 +10,9 @@ SET GLOBAL innodb_flush_log_at_trx_commit = 1; ...@@ -10,9 +10,9 @@ SET GLOBAL innodb_flush_log_at_trx_commit = 1;
ROLLBACK; ROLLBACK;
disconnect flush_log; disconnect flush_log;
connection default; connection default;
NOT FOUND /Rollback of trx with id/ in current_test NOT FOUND /Rolled back recovered transaction/ in current_test
# expect NOT FOUND # expect NOT FOUND
NOT FOUND /Rollback of trx with id/ in current_test NOT FOUND /Rolled back recovered transaction/ in current_test
# expect NOT FOUND # expect NOT FOUND
commit; commit;
SELECT count(*) FROM t; SELECT count(*) FROM t;
......
...@@ -40,7 +40,7 @@ exec $XTRABACKUP --prepare --apply-log-only --target-dir=$basedir ; ...@@ -40,7 +40,7 @@ exec $XTRABACKUP --prepare --apply-log-only --target-dir=$basedir ;
--enable_result_log --enable_result_log
let SEARCH_FILE=$MYSQLTEST_VARDIR/log/current_test; let SEARCH_FILE=$MYSQLTEST_VARDIR/log/current_test;
--let SEARCH_PATTERN= Rollback of trx with id --let SEARCH_PATTERN= Rolled back recovered transaction
--source include/search_pattern_in_file.inc --source include/search_pattern_in_file.inc
--echo # expect NOT FOUND --echo # expect NOT FOUND
......
...@@ -2,7 +2,7 @@ call mtr.add_suppression("InnoDB: New log files created"); ...@@ -2,7 +2,7 @@ call mtr.add_suppression("InnoDB: New log files created");
CREATE TABLE t(a varchar(60)) ENGINE INNODB; CREATE TABLE t(a varchar(60)) ENGINE INNODB;
start transaction; start transaction;
INSERT INTO t VALUES(1); INSERT INTO t VALUES(1);
NOT FOUND /Rollback of trx with id/ in current_test NOT FOUND /Rolled back recovered transaction/ in current_test
# expect NOT FOUND # expect NOT FOUND
SELECT count(*) FROM t; SELECT count(*) FROM t;
count(*) count(*)
......
...@@ -14,7 +14,7 @@ exec $XTRABACKUP --defaults-file=$MYSQLTEST_VARDIR/my.cnf --backup --target-dir ...@@ -14,7 +14,7 @@ exec $XTRABACKUP --defaults-file=$MYSQLTEST_VARDIR/my.cnf --backup --target-dir
exec $XTRABACKUP --prepare --apply-log-only --target-dir=$basedir ; exec $XTRABACKUP --prepare --apply-log-only --target-dir=$basedir ;
let SEARCH_FILE=$MYSQLTEST_VARDIR/log/current_test; let SEARCH_FILE=$MYSQLTEST_VARDIR/log/current_test;
--let SEARCH_PATTERN= Rollback of trx with id --let SEARCH_PATTERN= Rolled back recovered transaction
--source include/search_pattern_in_file.inc --source include/search_pattern_in_file.inc
--echo # expect NOT FOUND --echo # expect NOT FOUND
......
...@@ -627,6 +627,9 @@ trx_rollback_active( ...@@ -627,6 +627,9 @@ trx_rollback_active(
roll_node_t* roll_node; roll_node_t* roll_node;
dict_table_t* table; dict_table_t* table;
ibool dictionary_locked = FALSE; ibool dictionary_locked = FALSE;
const trx_id_t trx_id = trx->id;
ut_ad(trx_id);
heap = mem_heap_create(512); heap = mem_heap_create(512);
...@@ -698,14 +701,13 @@ trx_rollback_active( ...@@ -698,14 +701,13 @@ trx_rollback_active(
} }
} }
ib::info() << "Rolled back recovered transaction " << trx_id;
func_exit: func_exit:
if (dictionary_locked) { if (dictionary_locked) {
row_mysql_unlock_data_dictionary(trx); row_mysql_unlock_data_dictionary(trx);
} }
ib::info() << "Rollback of trx with id " << ib::hex(trx->id)
<< " completed";
mem_heap_free(heap); mem_heap_free(heap);
trx_roll_crash_recv_trx = NULL; trx_roll_crash_recv_trx = NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment