mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
Merge 11.4 into 11.8
This commit is contained in:
@@ -1,16 +1,15 @@
|
||||
***MDEV-5914: Parallel replication deadlock due to InnoDB lock conflicts ***
|
||||
include/master-slave.inc
|
||||
[connection master]
|
||||
connection server_2;
|
||||
SET sql_log_bin=0;
|
||||
ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB;
|
||||
CALL mtr.add_suppression("InnoDB: Transaction was aborted due to ");
|
||||
CALL mtr.add_suppression("Commit failed due to failure of an earlier commit on which this one depends");
|
||||
SET sql_log_bin=1;
|
||||
connection server_2;
|
||||
SET @old_parallel_threads=@@GLOBAL.slave_parallel_threads;
|
||||
include/stop_slave.inc
|
||||
SET GLOBAL slave_parallel_threads=10;
|
||||
CHANGE MASTER TO master_use_gtid=slave_pos;
|
||||
connection server_1;
|
||||
ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB;
|
||||
CREATE TABLE t4 (a INT PRIMARY KEY, b INT, KEY b_idx(b)) ENGINE=InnoDB;
|
||||
INSERT INTO t4 VALUES (1,NULL), (2,2), (3,NULL), (4,4), (5, NULL), (6, 6);
|
||||
connect con1,127.0.0.1,root,,test,$SERVER_MYPORT_1,;
|
||||
|
26
mysql-test/suite/rpl/r/rpl_xa_2pc_multi_engine.result
Normal file
26
mysql-test/suite/rpl/r/rpl_xa_2pc_multi_engine.result
Normal file
@@ -0,0 +1,26 @@
|
||||
include/master-slave.inc
|
||||
[connection master]
|
||||
connection master;
|
||||
create table t1 (a int primary key, b int) engine=innodb;
|
||||
insert t1 values (1,1),(3,3),(5,5),(7,7);
|
||||
create table t2 (m int) engine=aria;
|
||||
# Create multi-engine, two-phase XA transaction (T1)
|
||||
xa start '1';
|
||||
insert t2 values (1);
|
||||
update t1 set b=50 where b=5;
|
||||
xa end '1';
|
||||
xa prepare '1';
|
||||
# Create T2
|
||||
connection server_1;
|
||||
update t1 set b=10 where a=5;
|
||||
connection master;
|
||||
xa commit '1';
|
||||
connection server_1;
|
||||
include/save_master_gtid.inc
|
||||
# This would hang prior to MDEV-21117
|
||||
connection slave;
|
||||
include/sync_with_master_gtid.inc
|
||||
connection master;
|
||||
drop table t1, t2;
|
||||
include/rpl_end.inc
|
||||
# End of rpl_xa_2pc_multi_engine.test
|
@@ -5,21 +5,19 @@
|
||||
--source include/have_debug_sync.inc
|
||||
--source include/master-slave.inc
|
||||
|
||||
--disable_query_log
|
||||
call mtr.add_suppression("InnoDB: Transaction was aborted due to ");
|
||||
--enable_query_log
|
||||
ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB;
|
||||
CALL mtr.add_suppression("InnoDB: Transaction was aborted due to ");
|
||||
CALL mtr.add_suppression("Commit failed due to failure of an earlier commit on which this one depends");
|
||||
--save_master_pos
|
||||
|
||||
--connection server_2
|
||||
SET sql_log_bin=0;
|
||||
CALL mtr.add_suppression("Commit failed due to failure of an earlier commit on which this one depends");
|
||||
SET sql_log_bin=1;
|
||||
--sync_with_master
|
||||
SET @old_parallel_threads=@@GLOBAL.slave_parallel_threads;
|
||||
--source include/stop_slave.inc
|
||||
SET GLOBAL slave_parallel_threads=10;
|
||||
CHANGE MASTER TO master_use_gtid=slave_pos;
|
||||
|
||||
--connection server_1
|
||||
ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB;
|
||||
CREATE TABLE t4 (a INT PRIMARY KEY, b INT, KEY b_idx(b)) ENGINE=InnoDB;
|
||||
INSERT INTO t4 VALUES (1,NULL), (2,2), (3,NULL), (4,4), (5, NULL), (6, 6);
|
||||
--connect (con1,127.0.0.1,root,,test,$SERVER_MYPORT_1,)
|
||||
|
63
mysql-test/suite/rpl/t/rpl_xa_2pc_multi_engine.test
Normal file
63
mysql-test/suite/rpl/t/rpl_xa_2pc_multi_engine.test
Normal file
@@ -0,0 +1,63 @@
|
||||
#
|
||||
# This test ensures binlog order is correct for multi-engine, two-phase XA
|
||||
# transactions. MDEV-26652 exposed a race condition which would allow
|
||||
# concurrent transactions which modify the same table record to binlog in
|
||||
# the "opposite" order, i.e. what _should_ be:
|
||||
# T1 XA PREPARE
|
||||
# T1 XA COMMIT
|
||||
# T2
|
||||
#
|
||||
# was binlogged as
|
||||
# T1 XA PREPARE
|
||||
# T2
|
||||
# T1 XA COMMIT
|
||||
#
|
||||
# which would break replication.
|
||||
#
|
||||
# Note that the actual fix for this issue was done with MDEV-21117.
|
||||
#
|
||||
# References:
|
||||
# MDEV-26652: xa transactions binlogged in wrong order
|
||||
# MDEV-21117: refine the server binlog-based recovery for semisync
|
||||
#
|
||||
source include/have_binlog_format_row.inc;
|
||||
source include/have_innodb.inc;
|
||||
source include/master-slave.inc;
|
||||
|
||||
--connection master
|
||||
create table t1 (a int primary key, b int) engine=innodb;
|
||||
insert t1 values (1,1),(3,3),(5,5),(7,7);
|
||||
create table t2 (m int) engine=aria;
|
||||
|
||||
|
||||
--echo # Create multi-engine, two-phase XA transaction (T1)
|
||||
xa start '1';
|
||||
insert t2 values (1);
|
||||
update t1 set b=50 where b=5;
|
||||
xa end '1';
|
||||
|
||||
# Aria doesn't support XA PREPARE, so disable warnings
|
||||
--disable_warnings
|
||||
xa prepare '1';
|
||||
--enable_warnings
|
||||
|
||||
--echo # Create T2
|
||||
--connection server_1
|
||||
--send update t1 set b=10 where a=5
|
||||
|
||||
--connection master
|
||||
xa commit '1';
|
||||
|
||||
--connection server_1
|
||||
--reap
|
||||
--source include/save_master_gtid.inc
|
||||
|
||||
--echo # This would hang prior to MDEV-21117
|
||||
--connection slave
|
||||
--source include/sync_with_master_gtid.inc
|
||||
|
||||
--connection master
|
||||
drop table t1, t2;
|
||||
|
||||
--source include/rpl_end.inc
|
||||
--echo # End of rpl_xa_2pc_multi_engine.test
|
Reference in New Issue
Block a user