mariadb/mysql-test/suite/multi_source
Marko Mäkelä ddd7d5d8e3 MDEV-24035 Failing assertion: UT_LIST_GET_LEN(lock.trx_locks) == 0 causing disruption and replication failure
Under unknown circumstances, the SQL layer may wrongly disregard an
invocation of thd_mark_transaction_to_rollback() when an InnoDB
transaction had been aborted (rolled back) due to one of the following errors:
* HA_ERR_LOCK_DEADLOCK
* HA_ERR_RECORD_CHANGED (if innodb_snapshot_isolation=ON)
* HA_ERR_LOCK_WAIT_TIMEOUT (if innodb_rollback_on_timeout=ON)

Such an error used to cause a crash of InnoDB during transaction commit.
These changes aim to catch and report the error earlier, so that not only
this crash can be avoided but also the original root cause be found and
fixed more easily later.

The idea of this fix is from Michael 'Monty' Widenius.

HA_ERR_ROLLBACK: A new error code that will be translated into
ER_ROLLBACK_ONLY, signalling that the current transaction
has been aborted and the only allowed action is ROLLBACK.

trx_t::state: Add TRX_STATE_ABORTED that is like
TRX_STATE_NOT_STARTED, but noting that the transaction had been
rolled back and aborted.

trx_t::is_started(): Replaces trx_is_started().

ha_innobase: Check the transaction state in various places.
Simplify the logic around SAVEPOINT.

ha_innobase::is_valid_trx(): Replaces ha_innobase::is_read_only().

The InnoDB logic around transaction savepoints, commit, and rollback
was unnecessarily complex and might have contributed to this
inconsistency. So, we are simplifying that logic as well.

trx_savept_t: Replace with const undo_no_t*. When we rollback to
a savepoint, all we need to know is the number of undo log records
that must survive.

trx_named_savept_t, DB_NO_SAVEPOINT: Remove. We can store undo_no_t
directly in the space allocated at innobase_hton->savepoint_offset.

fts_trx_create(): Do not copy previous savepoints.

fts_savepoint_rollback(): If a savepoint was not found, roll back
everything after the default savepoint of fts_trx_create().
The test innodb_fts.savepoint is extended to cover this code.

Reviewed by: Vladislav Lesin
Tested by: Matthias Leich
2024-12-12 18:02:00 +02:00
..
disabled.def MDEV-20101 Assertion failure on select @@global.'m2'.replicate_ignore_table; 2019-08-05 16:03:33 +04:00
gtid.cnf
gtid.result MDEV-6720 - enable connection log in mysqltest by default 2016-03-31 10:11:16 +04:00
gtid.test MDEV-9038 Binlog encryption tests 2016-12-05 20:19:01 +02:00
gtid_ignore_duplicates.cnf
gtid_ignore_duplicates.result MDEV-33475: --gtid-ignore-duplicate can double-apply event in case of parallel replication retry 2024-03-13 16:59:10 +01:00
gtid_ignore_duplicates.test MDEV-24035 Failing assertion: UT_LIST_GET_LEN(lock.trx_locks) == 0 causing disruption and replication failure 2024-12-12 18:02:00 +02:00
gtid_slave_pos.result MDEV-32168: slave_error_param condition is never checked from the wait_for_slave_param.inc 2023-11-28 19:10:42 +01:00
gtid_slave_pos.test MDEV-32168: slave_error_param condition is never checked from the wait_for_slave_param.inc 2023-11-28 19:10:42 +01:00
info_logs-master.opt
info_logs.result perfschema compilation, test and misc fixes 2020-03-10 19:24:23 +01:00
info_logs.test MDEV-23511 shutdown_server 10 times out, causing server kill at shutdown 2020-08-21 14:48:53 +03:00
load_data.result MDEV-6720 - enable connection log in mysqltest by default 2016-03-31 10:11:16 +04:00
load_data.test MDEV-9038 Binlog encryption tests 2016-12-05 20:19:01 +02:00
mdev-8874.cnf MDEV-8874 Replication filters configured in my.cnf are ignored if slave reset and reconfigured 2019-06-27 09:54:20 +05:30
mdev-8874.result post-merge fixes 2019-07-09 22:24:50 +03:00
mdev-8874.test MDEV-8874 Replication filters configured in my.cnf are ignored if slave reset and reconfigured 2019-06-27 09:54:20 +05:30
mdev-9544.cnf MDEV-9544 FLUSH [RELAY] LOGS does not rotate logs for a named slave 2017-06-05 13:11:10 +05:30
mdev-9544.result MDEV-9544 Fix test case for 10.2 2017-06-10 12:57:59 +05:30
mdev-9544.test Fixed some mtr tests that failed on windows 2024-01-23 13:03:12 +02:00
multi_parallel.cnf Mdev-10664 Add statuses about optimistic parallel replication stalls 2018-04-19 16:04:23 +05:30
multi_parallel.result Mdev-10664 Add statuses about optimistic parallel replication stalls 2018-04-19 16:04:23 +05:30
multi_parallel.test Valgrind: Disable tests that would often time out 2022-07-01 14:42:13 +03:00
multi_parallel_loop.inc Mdev-10664 Add statuses about optimistic parallel replication stalls 2018-04-19 16:04:23 +05:30
multi_source_slave_alias_replica.result perfschema compilation, test and misc fixes 2020-03-10 19:24:23 +01:00
multi_source_slave_alias_replica.test MDEV-20601: Make REPLICA a synonym for SLAVE in SQL statements 2020-02-04 18:16:21 +05:30
multisource.result MDEV-16437: merge 5.7 P_S replication instrumentation and tables 2021-04-16 09:02:00 +05:30
multisource.test Move mysql-test-run/extra/rpl_tests to suite/rpl/include 2018-03-29 13:59:44 +03:00
my.cnf
relaylog_events.result MDEV-6720 - enable connection log in mysqltest by default 2016-03-31 10:11:16 +04:00
relaylog_events.test MDEV-9038 Binlog encryption tests 2016-12-05 20:19:01 +02:00
reset_slave.result MDEV-18648: slave_parallel_mode= optimistic default in 10.5 2019-12-23 17:48:01 +05:30
reset_slave.test MDEV-24576 Atomic CREATE TABLE 2021-05-19 22:54:13 +02:00
simple.result MDEV-16437: merge 5.7 P_S replication instrumentation and tables 2021-04-16 09:02:00 +05:30
simple.test MDEV-16437: merge 5.7 P_S replication instrumentation and tables 2021-04-16 09:02:00 +05:30
skip_counter.result MDEV-6720 - enable connection log in mysqltest by default 2016-03-31 10:11:16 +04:00
skip_counter.test MDEV-9038 Binlog encryption tests 2016-12-05 20:19:01 +02:00
status_vars.result MDEV-6720 - enable connection log in mysqltest by default 2016-03-31 10:11:16 +04:00
status_vars.test MDEV-9038 Binlog encryption tests 2016-12-05 20:19:01 +02:00
syntax.result Mdev-10664 Add statuses about optimistic parallel replication stalls 2018-04-19 16:04:23 +05:30
syntax.test