mirror of
https://github.com/MariaDB/server.git
synced 2025-05-28 13:01:41 +03:00
Replace CHANGE MASTER TO ... master_gtid_pos='xxx' with a new system variable @@global.gtid_pos. This is more logical; @@gtid_pos is global, not per-master, and it is not affected by RESET SLAVE. Also rename master_gtid_pos=AUTO to master_use_gtid=1, which again is more logical.
123 lines
3.5 KiB
Plaintext
123 lines
3.5 KiB
Plaintext
--source include/have_innodb.inc
|
|
--let $rpl_topology=1->2->3->4
|
|
--source include/rpl_init.inc
|
|
|
|
# Set up a 4-deep replication topology, then test various fail-overs
|
|
# using GTID.
|
|
#
|
|
# A -> B -> C -> D
|
|
|
|
connection server_1;
|
|
CREATE TABLE t1 (a INT PRIMARY KEY, b VARCHAR(10)) ENGINE=MyISAM;
|
|
CREATE TABLE t2 (a INT PRIMARY KEY, b VARCHAR(10)) ENGINE=InnoDB;
|
|
INSERT INTO t1 VALUES (1, "m1");
|
|
INSERT INTO t1 VALUES (2, "m2"), (3, "m3"), (4, "m4");
|
|
INSERT INTO t2 VALUES (1, "i1");
|
|
BEGIN;
|
|
INSERT INTO t2 VALUES (2, "i2"), (3, "i3");
|
|
INSERT INTO t2 VALUES (4, "i4");
|
|
COMMIT;
|
|
save_master_pos;
|
|
|
|
connection server_2;
|
|
sync_with_master;
|
|
SELECT * FROM t1 ORDER BY a;
|
|
SELECT * FROM t2 ORDER BY a;
|
|
save_master_pos;
|
|
|
|
connection server_3;
|
|
sync_with_master;
|
|
SELECT * FROM t1 ORDER BY a;
|
|
SELECT * FROM t2 ORDER BY a;
|
|
save_master_pos;
|
|
|
|
connection server_4;
|
|
sync_with_master;
|
|
SELECT * FROM t1 ORDER BY a;
|
|
SELECT * FROM t2 ORDER BY a;
|
|
|
|
|
|
--echo *** Now take out D, let it fall behind a bit, and then test re-attaching it to A ***
|
|
connection server_4;
|
|
--source include/stop_slave.inc
|
|
|
|
connection server_1;
|
|
INSERT INTO t1 VALUES (5, "m1a");
|
|
INSERT INTO t2 VALUES (5, "i1a");
|
|
save_master_pos;
|
|
|
|
connection server_4;
|
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
|
eval CHANGE MASTER TO master_host = '127.0.0.1', master_port = $MASTER_MYPORT,
|
|
MASTER_USE_GTID=1;
|
|
--source include/start_slave.inc
|
|
sync_with_master;
|
|
SELECT * FROM t1 ORDER BY a;
|
|
SELECT * FROM t2 ORDER BY a;
|
|
|
|
--echo *** Now move B to D (C is still replicating from B) ***
|
|
connection server_2;
|
|
--source include/stop_slave.inc
|
|
--replace_result $SERVER_MYPORT_4 SERVER_MYPORT_4
|
|
eval CHANGE MASTER TO master_host = '127.0.0.1', master_port = $SERVER_MYPORT_4,
|
|
MASTER_USE_GTID=1;
|
|
--source include/start_slave.inc
|
|
|
|
connection server_4;
|
|
UPDATE t2 SET b="j1a" WHERE a=5;
|
|
save_master_pos;
|
|
|
|
connection server_2;
|
|
sync_with_master;
|
|
SELECT * FROM t1 ORDER BY a;
|
|
SELECT * FROM t2 ORDER BY a;
|
|
|
|
--echo *** Now move C to D, after letting it fall a little behind ***
|
|
connection server_3;
|
|
--source include/stop_slave.inc
|
|
|
|
connection server_1;
|
|
BEGIN;
|
|
INSERT INTO t2 VALUES (6, "i6b");
|
|
INSERT INTO t2 VALUES (7, "i7b");
|
|
COMMIT;
|
|
|
|
connection server_3;
|
|
--replace_result $SERVER_MYPORT_4 SERVER_MYPORT_4
|
|
eval CHANGE MASTER TO master_host = '127.0.0.1', master_port = $SERVER_MYPORT_4,
|
|
MASTER_USE_GTID=1;
|
|
--source include/start_slave.inc
|
|
# This time, let's sync up without reference to binlog on D.
|
|
--let $wait_condition= SELECT COUNT(*) = 7 FROM t2
|
|
--source include/wait_condition.inc
|
|
SELECT * FROM t2 ORDER BY a;
|
|
|
|
--echo *** Now change everything back to what it was, to make rpl_end.inc happy
|
|
# Also check that MASTER_USE_GTID=1 is still enabled.
|
|
connection server_2;
|
|
--source include/stop_slave.inc
|
|
--replace_result $MASTER_MYPORT MASTER_MYPORT
|
|
eval CHANGE MASTER TO master_host = '127.0.0.1', master_port = $MASTER_MYPORT;
|
|
--source include/start_slave.inc
|
|
--let $wait_condition= SELECT COUNT(*) = 7 FROM t2
|
|
--source include/wait_condition.inc
|
|
|
|
connection server_3;
|
|
--source include/stop_slave.inc
|
|
--replace_result $SLAVE_MYPORT SLAVE_MYPORT
|
|
eval CHANGE MASTER TO master_host = '127.0.0.1', master_port = $SLAVE_MYPORT;
|
|
--source include/start_slave.inc
|
|
--let $wait_condition= SELECT COUNT(*) = 7 FROM t2
|
|
--source include/wait_condition.inc
|
|
|
|
connection server_4;
|
|
--source include/stop_slave.inc
|
|
--replace_result $SERVER_MYPORT_3 SERVER_MYPORT_3
|
|
eval CHANGE MASTER TO master_host = '127.0.0.1', master_port = $SERVER_MYPORT_3;
|
|
--source include/start_slave.inc
|
|
|
|
connection server_1;
|
|
DROP TABLE t1,t2;
|
|
|
|
--source include/rpl_end.inc
|