mirror of
https://github.com/MariaDB/server.git
synced 2025-02-04 21:02:17 +01:00
788953463d
Some fixes related to commit f838b2d799
and
Rows_log_event::do_apply_event() and Update_rows_log_event::do_exec_row()
for system-versioned tables were provided by Nikita Malyavin.
This was required by test versioning.rpl,trx_id,row.
229 lines
6.3 KiB
Text
229 lines
6.3 KiB
Text
include/rpl_init.inc [topology=1->2]
|
|
*** MDEV-6321: close_temporary_tables() in format description event not serialised correctly ***
|
|
connection server_2;
|
|
SET @old_parallel_threads=@@GLOBAL.slave_parallel_threads;
|
|
include/stop_slave.inc
|
|
SET GLOBAL slave_parallel_threads=5;
|
|
include/start_slave.inc
|
|
connection server_1;
|
|
CREATE TABLE t1 (a INT PRIMARY KEY, b VARCHAR(100) CHARACTER SET utf8);
|
|
connection server_2;
|
|
include/stop_slave.inc
|
|
connection server_1;
|
|
SET gtid_domain_id= 1;
|
|
INSERT INTO t1 VALUES (1, 0);
|
|
CREATE TEMPORARY TABLE t2 (a int);
|
|
connection default;
|
|
SET gtid_domain_id= 2;
|
|
CREATE TEMPORARY TABLE t3 (a INT PRIMARY KEY);
|
|
CREATE TEMPORARY TABLE t4 (a int);
|
|
INSERT INTO t3 VALUES (100);
|
|
INSERT INTO t4 SELECT a+1 FROM t3;
|
|
connection server_1;
|
|
INSERT INTO t2 VALUES (2), (4), (6), (8), (10), (12), (14), (16), (18), (20);
|
|
INSERT INTO t2 VALUES (3), (6), (9), (12), (15), (18);
|
|
INSERT INTO t2 VALUES (4), (8), (12), (16), (20);
|
|
connection default;
|
|
INSERT INTO t3 SELECT a+2 FROM t4;
|
|
INSERT INTO t4 SELECT a+4 FROM t3;
|
|
connection server_1;
|
|
INSERT INTO t2 VALUES (5), (10), (15), (20);
|
|
INSERT INTO t2 VALUES (6), (12), (18);
|
|
INSERT INTO t2 VALUES (7), (14);
|
|
INSERT INTO t2 VALUES (8), (16);
|
|
INSERT INTO t2 VALUES (9), (18);
|
|
INSERT INTO t2 VALUES (10), (20);
|
|
connection default;
|
|
INSERT INTO t3 SELECT a+8 FROM t4;
|
|
INSERT INTO t4 SELECT a+16 FROM t3;
|
|
connection server_1;
|
|
INSERT INTO t2 VALUES (11);
|
|
INSERT INTO t2 VALUES (12);
|
|
INSERT INTO t2 VALUES (13);
|
|
connection default;
|
|
INSERT INTO t3 SELECT a+32 FROM t4;
|
|
connection server_1;
|
|
INSERT INTO t2 VALUES (14);
|
|
INSERT INTO t2 VALUES (15);
|
|
INSERT INTO t2 VALUES (16);
|
|
connection default;
|
|
INSERT INTO t4 SELECT a+64 FROM t3;
|
|
connection server_1;
|
|
INSERT INTO t2 VALUES (17);
|
|
INSERT INTO t2 VALUES (18);
|
|
INSERT INTO t2 VALUES (19);
|
|
connection default;
|
|
INSERT INTO t3 SELECT a+128 FROM t4;
|
|
connection server_1;
|
|
INSERT INTO t2 VALUES (20);
|
|
connection default;
|
|
INSERT INTO t1 SELECT a, a MOD 7 FROM t3;
|
|
INSERT INTO t1 SELECT a, a MOD 7 FROM t4;
|
|
connection server_1;
|
|
INSERT INTO t1 SELECT a, COUNT(*) FROM t2 GROUP BY a;
|
|
FLUSH TABLES;
|
|
SET SESSION debug_dbug="+d,crash_dispatch_command_before";
|
|
SELECT 1;
|
|
Got one of the listed errors
|
|
connection default;
|
|
connection default;
|
|
connection server_1;
|
|
INSERT INTO t1 VALUES (0, 1);
|
|
connection server_2;
|
|
include/start_slave.inc
|
|
SELECT * FROM t1 WHERE a <= 20 ORDER BY a;
|
|
a b
|
|
0 1
|
|
1 0
|
|
2 1
|
|
3 1
|
|
4 2
|
|
5 1
|
|
6 3
|
|
7 1
|
|
8 3
|
|
9 2
|
|
10 3
|
|
11 1
|
|
12 5
|
|
13 1
|
|
14 3
|
|
15 3
|
|
16 4
|
|
17 1
|
|
18 5
|
|
19 1
|
|
20 5
|
|
SELECT COUNT(*) FROM t1 WHERE a BETWEEN 100+0 AND 100+256;
|
|
COUNT(*)
|
|
55
|
|
SHOW STATUS LIKE 'Slave_open_temp_tables';
|
|
Variable_name Value
|
|
Slave_open_temp_tables 0
|
|
*** Test that if master logged partial event group before crash, we finish that group correctly before executing format description event ***
|
|
include/stop_slave.inc
|
|
connection server_1;
|
|
CALL mtr.add_suppression("Statement accesses nontransactional table as well as transactional or temporary table, and writes to any of them");
|
|
SET gtid_domain_id= 1;
|
|
DELETE FROM t1;
|
|
ALTER TABLE t1 ENGINE=InnoDB;
|
|
CREATE TEMPORARY TABLE t2 (a INT PRIMARY KEY);
|
|
INSERT INTO t2 VALUES (1);
|
|
INSERT INTO t2 VALUES (2);
|
|
connection default;
|
|
SET gtid_domain_id= 2;
|
|
CREATE TEMPORARY TABLE t3 (a INT PRIMARY KEY);
|
|
INSERT INTO t3 VALUES (10);
|
|
INSERT INTO t3 VALUES (20);
|
|
connection server_1;
|
|
INSERT INTO t1 SELECT a, 'server_1' FROM t2;
|
|
connection default;
|
|
INSERT INTO t1 SELECT a, 'default' FROM t3;
|
|
connection server_1;
|
|
INSERT INTO t1 SELECT a+2, '+server_1' FROM t2;
|
|
FLUSH TABLES;
|
|
SET SESSION debug_dbug="+d,crash_before_writing_xid";
|
|
INSERT INTO t1 SELECT a+4, '++server_1' FROM t2;
|
|
Got one of the listed errors
|
|
connection default;
|
|
connection default;
|
|
connection server_1;
|
|
INSERT INTO t1 VALUES (0, 1);
|
|
include/save_master_gtid.inc
|
|
connection server_2;
|
|
set @@sql_log_bin=0;
|
|
call mtr.add_suppression("Unexpected break of being relay-logged GTID 1-1-32 event group by the current GTID event 0-1-4");
|
|
set @@sql_log_bin=1;
|
|
set @@global.debug_dbug="+d,slave_discard_xid_for_gtid_0_x_1000";
|
|
include/start_slave.inc
|
|
include/sync_with_master_gtid.inc
|
|
set @@global.debug_dbug="";
|
|
SELECT * FROM t1 ORDER BY a;
|
|
a b
|
|
0 1
|
|
1 server_1
|
|
2 server_1
|
|
3 +server_1
|
|
4 +server_1
|
|
10 default
|
|
20 default
|
|
SHOW STATUS LIKE 'Slave_open_temp_tables';
|
|
Variable_name Value
|
|
Slave_open_temp_tables 0
|
|
connection server_1;
|
|
FLUSH LOGS;
|
|
*** MDEV-7936: Assertion `!table || table->in_use == _current_thd()' failed on parallel replication in optimistic mode ***
|
|
connection server_1;
|
|
CREATE TEMPORARY TABLE t4 (a INT PRIMARY KEY) ENGINE=InnoDB;
|
|
SET @old_dbug= @@SESSION.debug_dbug;
|
|
SET SESSION debug_dbug="+d,binlog_force_commit_id";
|
|
SET @commit_id= 10000;
|
|
INSERT INTO t4 VALUES (30);
|
|
INSERT INTO t4 VALUES (31);
|
|
SET SESSION debug_dbug= @old_dbug;
|
|
INSERT INTO t1 SELECT a, "conservative" FROM t4;
|
|
DROP TEMPORARY TABLE t4;
|
|
SELECT * FROM t1 WHERE a >= 30 ORDER BY a;
|
|
a b
|
|
30 conservative
|
|
31 conservative
|
|
include/save_master_gtid.inc
|
|
connection server_2;
|
|
include/sync_with_master_gtid.inc
|
|
SELECT * FROM t1 WHERE a >= 30 ORDER BY a;
|
|
a b
|
|
30 conservative
|
|
31 conservative
|
|
include/stop_slave.inc
|
|
SET @old_mode= @@GLOBAL.slave_parallel_mode;
|
|
SET GLOBAL slave_parallel_mode=optimistic;
|
|
connection server_1;
|
|
CREATE TEMPORARY TABLE t4 (a INT PRIMARY KEY) ENGINE=InnoDB;
|
|
INSERT INTO t4 VALUES (32);
|
|
INSERT INTO t4 VALUES (33);
|
|
INSERT INTO t1 SELECT a, "optimistic" FROM t4;
|
|
DROP TEMPORARY TABLE t4;
|
|
SELECT * FROM t1 WHERE a >= 30 ORDER BY a;
|
|
a b
|
|
30 conservative
|
|
31 conservative
|
|
32 optimistic
|
|
33 optimistic
|
|
include/save_master_gtid.inc
|
|
connection server_2;
|
|
include/start_slave.inc
|
|
include/sync_with_master_gtid.inc
|
|
SELECT * FROM t1 WHERE a >= 30 ORDER BY a;
|
|
a b
|
|
30 conservative
|
|
31 conservative
|
|
32 optimistic
|
|
33 optimistic
|
|
include/stop_slave.inc
|
|
SET GLOBAL slave_parallel_mode=@old_mode;
|
|
include/start_slave.inc
|
|
*** MDEV33426: Memory allocation accounting incorrect for replicated temptable
|
|
connection server_1;
|
|
CREATE TEMPORARY TABLE t5 (a int) ENGINE=Aria;
|
|
CREATE TEMPORARY TABLE t6 (a int) ENGINE=Heap;
|
|
INSERT INTO t5 VALUES (1);
|
|
INSERT INTO t6 VALUES (2);
|
|
connection server_2;
|
|
include/stop_slave.inc
|
|
connection server_1;
|
|
INSERT INTO t1 SELECT a+40, 5 FROM t5;
|
|
INSERT INTO t1 SELECT a+40, 6 FROM t6;
|
|
DROP TABLE t5, t6;
|
|
connection server_2;
|
|
include/start_slave.inc
|
|
SELECT * FROM t1 WHERE a>=40 ORDER BY a;
|
|
a b
|
|
41 5
|
|
42 6
|
|
connection server_2;
|
|
include/stop_slave.inc
|
|
SET GLOBAL slave_parallel_threads=@old_parallel_threads;
|
|
include/start_slave.inc
|
|
connection server_1;
|
|
DROP TABLE t1;
|
|
include/rpl_end.inc
|