mirror of
https://github.com/MariaDB/server.git
synced 2025-02-09 23:24:11 +01:00
![Sergei Golubchik](/assets/img/avatar_default.png)
Specifically: Revert "MDEV-29664 Assertion `!n_mysql_tables_in_use' failed in innobase_close_connection" This reverts commitba875e9396
. Revert "MDEV-29620 Assertion `next_insert_id == 0' failed in handler::ha_external_lock" This reverts commitaa08a7442a
. Revert "MDEV-29628 Memory leak after CREATE OR REPLACE with foreign key" This reverts commitc579d66ba6
. Revert "MDEV-29609 create_not_windows test fails with different result" This reverts commitcb583b2f1b
. Revert "MDEV-29544 SIGSEGV in HA_CREATE_INFO::finalize_locked_tables" This reverts commitdcd66c3814
. Revert "MDEV-28933 CREATE OR REPLACE fails to recreate same constraint name" This reverts commitcf6c517632
. Revert "MDEV-28933 Moved RENAME_CONSTRAINT_IDS to include/sql_funcs.h" This reverts commitf1e1c1335b
. Revert "MDEV-28956 Locking is broken if CREATE OR REPLACE fails under LOCK TABLES" This reverts commita228ec80e3
. Revert "MDEV-25292 gcol.gcol_bugfixes --ps fix" This reverts commit24fff8267d
. Revert "MDEV-25292 Disable atomic replace for slave-generated or-replace" This reverts commit2af15914cb
. Revert "MDEV-25292 backup_log improved" This reverts commit34398a20b5
. Revert "MDEV-25292 Atomic CREATE OR REPLACE TABLE" This reverts commit93c8252f02
. Revert "MDEV-25292 Table_name class for (db, table_name, alias)" This reverts commitd145dda9c7
. Revert "MDEV-25292 ha_table_exists() cleanup and improvement" This reverts commit409b8a86de
. Revert "MDEV-25292 Cleanups" This reverts commit595dad83ad
. Revert "MDEV-25292 Refactoring: moved select_field_count into Alter_info." This reverts commitf02af1d229
.
198 lines
7.3 KiB
Text
198 lines
7.3 KiB
Text
include/rpl_init.inc [topology=1->2]
|
|
connection server_1;
|
|
ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB;
|
|
SET sql_log_bin= 0;
|
|
call mtr.add_suppression("Error writing file .*errno: 1950");
|
|
SET sql_log_bin= 1;
|
|
SET @old_gtid_strict_mode= @@GLOBAL.gtid_strict_mode;
|
|
SET GLOBAL gtid_strict_mode= 1;
|
|
connection server_2;
|
|
include/stop_slave.inc
|
|
SET @old_gtid_strict_mode= @@GLOBAL.gtid_strict_mode;
|
|
SET GLOBAL gtid_strict_mode=1;
|
|
CHANGE MASTER TO master_use_gtid=slave_pos;
|
|
include/start_slave.inc
|
|
connection server_1;
|
|
CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=InnoDB;
|
|
INSERT INTO t1 VALUES (1);
|
|
include/show_binlog_events.inc
|
|
Log_name Pos Event_type Server_id End_log_pos Info
|
|
master-bin.000001 # Gtid # # GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB
|
|
master-bin.000001 # Gtid # # GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=InnoDB
|
|
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (1)
|
|
master-bin.000001 # Xid # # COMMIT /* XID */
|
|
SET server_id= 3;
|
|
SET gtid_seq_no= 3;
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-3 which would create an out-of-order sequence number with existing GTID 0-1-3, and gtid strict mode is enabled
|
|
SET @old_dbug = @@session.debug_dbug;
|
|
SET SESSION debug_dbug="d,ignore_set_gtid_seq_no_check";
|
|
SET gtid_seq_no= 3;
|
|
SET SESSION debug_dbug=@old_dbug;
|
|
INSERT INTO t1 VALUES (2);
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-3 which would create an out-of-order sequence number with existing GTID 0-1-3, and gtid strict mode is enabled
|
|
SET gtid_seq_no= 2;
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-2 which would create an out-of-order sequence number with existing GTID 0-1-3, and gtid strict mode is enabled
|
|
SET SESSION debug_dbug="d,ignore_set_gtid_seq_no_check";
|
|
SET gtid_seq_no= 2;
|
|
SET SESSION debug_dbug=@old_dbug;
|
|
INSERT INTO t1 VALUES (3);
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-2 which would create an out-of-order sequence number with existing GTID 0-1-3, and gtid strict mode is enabled
|
|
SET server_id= 1;
|
|
SET gtid_seq_no= 4;
|
|
INSERT INTO t1 VALUES (4);
|
|
SELECT * FROM t1 ORDER BY 1;
|
|
a
|
|
1
|
|
4
|
|
include/show_binlog_events.inc
|
|
Log_name Pos Event_type Server_id End_log_pos Info
|
|
master-bin.000001 # Gtid # # GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB
|
|
master-bin.000001 # Gtid # # GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=InnoDB
|
|
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (1)
|
|
master-bin.000001 # Xid # # COMMIT /* XID */
|
|
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (4)
|
|
master-bin.000001 # Xid # # COMMIT /* XID */
|
|
*** Test non-transactional GTID error (cannot be rolled back). ***
|
|
SET server_id= 3;
|
|
SET gtid_seq_no= 1;
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-1 which would create an out-of-order sequence number with existing GTID 0-1-4, and gtid strict mode is enabled
|
|
SET SESSION debug_dbug="d,ignore_set_gtid_seq_no_check";
|
|
SET gtid_seq_no= 1;
|
|
SET SESSION debug_dbug=@old_dbug;
|
|
CREATE TABLE t2 (a INT PRIMARY KEY) ENGINE=MyISAM;
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-1 which would create an out-of-order sequence number with existing GTID 0-1-4, and gtid strict mode is enabled
|
|
SET sql_log_bin= 0;
|
|
DROP TABLE t2;
|
|
SET sql_log_bin= 1;
|
|
CREATE TABLE t2 (a INT PRIMARY KEY) ENGINE=MyISAM;
|
|
SET gtid_seq_no= 1;
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-1 which would create an out-of-order sequence number with existing GTID 0-3-5, and gtid strict mode is enabled
|
|
SET SESSION debug_dbug="d,ignore_set_gtid_seq_no_check";
|
|
SET gtid_seq_no= 1;
|
|
SET SESSION debug_dbug=@old_dbug;
|
|
INSERT INTO t2 VALUES (1);
|
|
ERROR HY000: An attempt was made to binlog GTID 0-3-1 which would create an out-of-order sequence number with existing GTID 0-3-5, and gtid strict mode is enabled
|
|
SET server_id= 1;
|
|
SET gtid_seq_no= 6;
|
|
INSERT INTO t2 VALUES (2);
|
|
SELECT * FROM t2 ORDER BY a;
|
|
a
|
|
1
|
|
2
|
|
include/show_binlog_events.inc
|
|
Log_name Pos Event_type Server_id End_log_pos Info
|
|
master-bin.000001 # Gtid # # GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; ALTER TABLE mysql.gtid_slave_pos ENGINE=InnoDB
|
|
master-bin.000001 # Gtid # # GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=InnoDB
|
|
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (1)
|
|
master-bin.000001 # Xid # # COMMIT /* XID */
|
|
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (4)
|
|
master-bin.000001 # Xid # # COMMIT /* XID */
|
|
master-bin.000001 # Gtid # # GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; CREATE TABLE t2 (a INT PRIMARY KEY) ENGINE=MyISAM
|
|
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
|
master-bin.000001 # Query # # use `test`; INSERT INTO t2 VALUES (2)
|
|
master-bin.000001 # Query # # COMMIT
|
|
*** Test that slave stops if it tries to apply a GTID that would create out-of-order binlog GTID sequence numbers. ***
|
|
connection server_2;
|
|
SELECT * FROM t1 ORDER BY a;
|
|
a
|
|
1
|
|
4
|
|
SELECT * FROM t2 ORDER BY a;
|
|
a
|
|
2
|
|
SET sql_log_bin= 0;
|
|
call mtr.add_suppression("An attempt was made to binlog GTID .* which would create an out-of-order sequence number with existing GTID .*, and gtid strict mode is enabled");
|
|
call mtr.add_suppression("The binlog on the master is missing the GTID [-0-9]+ requested by the slave");
|
|
SET sql_log_bin= 1;
|
|
INSERT INTO t1 VALUES (5);
|
|
connection server_1;
|
|
INSERT INTO t1 VALUES (6);
|
|
connection server_2;
|
|
include/wait_for_slave_sql_error.inc [errno=1950]
|
|
STOP SLAVE IO_THREAD;
|
|
SET GLOBAL gtid_strict_mode=0;
|
|
include/start_slave.inc
|
|
SET GLOBAL gtid_strict_mode=1;
|
|
SELECT * FROM t1 ORDER BY a;
|
|
a
|
|
1
|
|
4
|
|
5
|
|
6
|
|
INSERT INTO t1 VALUES (7);
|
|
connection server_1;
|
|
CREATE TABLE t3 (a INT PRIMARY KEY);
|
|
connection server_2;
|
|
include/wait_for_slave_sql_error.inc [errno=1950]
|
|
SHOW CREATE TABLE t3;
|
|
ERROR 42S02: Table 'test.t3' doesn't exist
|
|
STOP SLAVE IO_THREAD;
|
|
SET GLOBAL gtid_strict_mode=0;
|
|
include/start_slave.inc
|
|
SET GLOBAL gtid_strict_mode=1;
|
|
SHOW CREATE TABLE t3;
|
|
Table t3
|
|
Create Table CREATE TABLE `t3` (
|
|
`a` int(11) NOT NULL,
|
|
PRIMARY KEY (`a`)
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci
|
|
INSERT INTO t1 VALUES (8);
|
|
connection server_1;
|
|
INSERT INTO t2 VALUES (3);
|
|
connection server_2;
|
|
include/wait_for_slave_sql_error.inc [errno=1950]
|
|
SELECT * FROM t2 ORDER BY a;
|
|
a
|
|
2
|
|
STOP SLAVE IO_THREAD;
|
|
SET GLOBAL gtid_strict_mode=0;
|
|
include/start_slave.inc
|
|
SET GLOBAL gtid_strict_mode=1;
|
|
SELECT * FROM t2 ORDER BY a;
|
|
a
|
|
2
|
|
3
|
|
*** Check slave requests starting from a hole on the master. ***
|
|
connection server_2;
|
|
include/stop_slave.inc
|
|
connection server_1;
|
|
INSERT INTO t1 VALUES (10);
|
|
SET gtid_seq_no= 100;
|
|
INSERT INTO t1 VALUES (11);
|
|
INSERT INTO t1 VALUES (12);
|
|
connection server_2;
|
|
SET GLOBAL gtid_slave_pos= "0-1-50";
|
|
START SLAVE;
|
|
include/wait_for_slave_io_error.inc [errno=1236]
|
|
STOP SLAVE SQL_THREAD;
|
|
SET GLOBAL gtid_strict_mode= 0;
|
|
include/start_slave.inc
|
|
SELECT * FROM t1 ORDER BY a;
|
|
a
|
|
1
|
|
4
|
|
5
|
|
6
|
|
7
|
|
8
|
|
11
|
|
12
|
|
SET GLOBAL gtid_strict_mode= 1;
|
|
connection server_1;
|
|
DROP TABLE t1, t2, t3;
|
|
SET GLOBAL gtid_strict_mode= @old_gtid_strict_mode;
|
|
connection server_2;
|
|
SET GLOBAL gtid_strict_mode= @old_gtid_strict_mode;
|
|
include/rpl_end.inc
|