mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 08:28:13 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			311 lines
		
	
	
	
		
			9.7 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			311 lines
		
	
	
	
		
			9.7 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| --source include/no_valgrind_without_big.inc
 | |
| --source include/have_innodb.inc
 | |
| --let $rpl_topology=1->2
 | |
| --source include/rpl_init.inc
 | |
| 
 | |
| --connection server_2
 | |
| call mtr.add_suppression("The automatically created table.*name may not be entirely in lowercase");
 | |
| 
 | |
| --error ER_SLAVE_MUST_STOP
 | |
| SET GLOBAL gtid_pos_auto_engines="innodb";
 | |
| --source include/stop_slave.inc
 | |
| CHANGE MASTER TO master_use_gtid=slave_pos;
 | |
| 
 | |
| # Test the @@gtid_pos_auto_engines sysvar.
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| --error ER_INCORRECT_GLOBAL_LOCAL_VAR
 | |
| SELECT @@SESSION.gtid_pos_auto_engines;
 | |
| --error ER_WRONG_VALUE_FOR_VAR
 | |
| SET GLOBAL gtid_pos_auto_engines= NULL;
 | |
| SET GLOBAL gtid_pos_auto_engines="innodb";
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| SET GLOBAL gtid_pos_auto_engines="myisam,innodb";
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| SET GLOBAL gtid_pos_auto_engines="innodb,myisam";
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| SET GLOBAL gtid_pos_auto_engines="innodb,innodb,myisam,innodb,myisam,myisam,innodb";
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| SET GLOBAL gtid_pos_auto_engines=DEFAULT;
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| SET GLOBAL gtid_pos_auto_engines="";
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| 
 | |
| --source include/start_slave.inc
 | |
| 
 | |
| --connection server_1
 | |
| CREATE TABLE t1 (a INT PRIMARY KEY);
 | |
| INSERT INTO t1 VALUES (1);
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| --save_master_pos
 | |
| 
 | |
| --connection server_2
 | |
| --sync_with_master
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| --source include/stop_slave.inc
 | |
| SET sql_log_bin=0;
 | |
| # Reset storage engine for mysql.gtid_slave_pos in case an earlier test
 | |
| # might have changed it to InnoDB.
 | |
| ALTER TABLE mysql.gtid_slave_pos ENGINE=Aria;
 | |
| CREATE TABLE mysql.gtid_slave_pos_innodb LIKE mysql.gtid_slave_pos;
 | |
| ALTER TABLE mysql.gtid_slave_pos_innodb ENGINE=InnoDB;
 | |
| INSERT INTO mysql.gtid_slave_pos_innodb SELECT * FROM mysql.gtid_slave_pos;
 | |
| TRUNCATE mysql.gtid_slave_pos;
 | |
| SET sql_log_bin=1;
 | |
| 
 | |
| # Restart the slave mysqld server, and verify that the GTID position is
 | |
| # read correctly from the new mysql.gtid_slave_pos_innodb table.
 | |
| 
 | |
| --write_line wait $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| --shutdown_server
 | |
| --source include/wait_until_disconnected.inc
 | |
| 
 | |
| --connection server_1
 | |
| INSERT INTO t1 VALUES (2);
 | |
| INSERT INTO t1 VALUES (3);
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| --source include/save_master_gtid.inc
 | |
| 
 | |
| # Let the slave mysqld server start again.
 | |
| # As we are restarting, also take the opportunity to test --gtid-pos-auto-engines
 | |
| --echo *** Restart server with --gtid-pos-auto-engines=innodb,myisam ***
 | |
| --append_file $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| restart: --skip-slave-start=0 --gtid-pos-auto-engines=innodb,myisam
 | |
| EOF
 | |
| 
 | |
| --connection server_2
 | |
| --enable_reconnect
 | |
| --source include/wait_until_connected_again.inc
 | |
| 
 | |
| --source include/sync_with_master_gtid.inc
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| 
 | |
| --echo *** Verify no new gtid_slave_pos* tables are created ***
 | |
| SELECT table_name, engine FROM information_schema.tables
 | |
|  WHERE table_schema='mysql' AND table_name LIKE 'gtid_slave_pos%'
 | |
|  ORDER BY table_name;
 | |
| 
 | |
| SELECT @@gtid_pos_auto_engines;
 | |
| --source include/stop_slave.inc
 | |
| SET sql_log_bin=0;
 | |
| INSERT INTO mysql.gtid_slave_pos_innodb SELECT * FROM mysql.gtid_slave_pos;
 | |
| DROP TABLE mysql.gtid_slave_pos;
 | |
| RENAME TABLE mysql.gtid_slave_pos_innodb TO mysql.gtid_slave_pos;
 | |
| SET sql_log_bin=1;
 | |
| 
 | |
| --write_line wait $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| --shutdown_server
 | |
| --source include/wait_until_disconnected.inc
 | |
| 
 | |
| --connection server_1
 | |
| CREATE TABLE t2 (a INT PRIMARY KEY) ENGINE=InnoDB;
 | |
| INSERT INTO t1 VALUES (4);
 | |
| INSERT INTO t2 VALUES (1);
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| --source include/save_master_gtid.inc
 | |
| 
 | |
| --echo *** Restart server with --gtid-pos-auto-engines=myisam,innodb ***
 | |
| --append_file $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| restart: --skip-slave-start=0 --gtid-pos-auto-engines=myisam,innodb
 | |
| EOF
 | |
| 
 | |
| --connection server_2
 | |
| --enable_reconnect
 | |
| --source include/wait_until_connected_again.inc
 | |
| 
 | |
| --source include/sync_with_master_gtid.inc
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| 
 | |
| --echo *** Verify that no new gtid_slave_pos* tables are auto-created ***
 | |
| SELECT table_name, engine FROM information_schema.tables
 | |
|  WHERE table_schema='mysql' AND table_name LIKE 'gtid_slave_pos%'
 | |
|  ORDER BY table_name;
 | |
| 
 | |
| 
 | |
| --source include/stop_slave.inc
 | |
| SET sql_log_bin=0;
 | |
| ALTER TABLE mysql.gtid_slave_pos ENGINE=Aria;
 | |
| SET sql_log_bin=1;
 | |
| 
 | |
| --write_line wait $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| --shutdown_server
 | |
| --source include/wait_until_disconnected.inc
 | |
| 
 | |
| --connection server_1
 | |
| INSERT INTO t1 VALUES (5);
 | |
| INSERT INTO t2 VALUES (2);
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| --source include/save_master_gtid.inc
 | |
| 
 | |
| --append_file $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| --echo *** Restart server with --gtid-pos-auto-engines=innodb ***
 | |
| restart: --skip-slave-start=0 --gtid-pos-auto-engines=innodb
 | |
| EOF
 | |
| 
 | |
| --connection server_2
 | |
| --enable_reconnect
 | |
| --source include/wait_until_connected_again.inc
 | |
| 
 | |
| --source include/sync_with_master_gtid.inc
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| 
 | |
| --echo *** Verify that mysql.gtid_slave_pos_InnoDB is auto-created ***
 | |
| # Note, the create happens asynchronously, so wait for it.
 | |
| let $wait_condition=
 | |
|   SELECT EXISTS (SELECT * FROM information_schema.tables
 | |
|                   WHERE table_schema='mysql' AND table_name='gtid_slave_pos_InnoDB');
 | |
| --source include/wait_condition.inc
 | |
| # MDEV-15373 lowercases 'table_name' to satisfy --lower-case-table-names options
 | |
| SELECT lower(table_name), engine FROM information_schema.tables
 | |
|  WHERE table_schema='mysql' AND table_name LIKE 'gtid_slave_pos%'
 | |
|  ORDER BY table_name;
 | |
| 
 | |
| 
 | |
| --source include/stop_slave.inc
 | |
| SET sql_log_bin=0;
 | |
| INSERT INTO mysql.gtid_slave_pos SELECT * FROM mysql.gtid_slave_pos_InnoDB;
 | |
| DROP TABLE mysql.gtid_slave_pos_InnoDB;
 | |
| SET sql_log_bin=1;
 | |
| 
 | |
| --write_line "wait" $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| --shutdown_server
 | |
| --source include/wait_until_disconnected.inc
 | |
| 
 | |
| --connection server_1
 | |
| INSERT INTO t1 VALUES (6);
 | |
| INSERT INTO t2 VALUES (3);
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| --source include/save_master_gtid.inc
 | |
| 
 | |
| --echo *** Restart server without --gtid-pos-auto-engines ***
 | |
| --append_file $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| restart: --skip-slave-start=0
 | |
| EOF
 | |
| 
 | |
| --connection server_2
 | |
| --enable_reconnect
 | |
| --source include/wait_until_connected_again.inc
 | |
| 
 | |
| --source include/sync_with_master_gtid.inc
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| 
 | |
| --echo *** Verify that no mysql.gtid_slave_pos* table is auto-created ***
 | |
| SELECT table_name, engine FROM information_schema.tables
 | |
|  WHERE table_schema='mysql' AND table_name LIKE 'gtid_slave_pos%'
 | |
|  ORDER BY table_name;
 | |
| SELECT domain_id, max(seq_no) FROM mysql.gtid_slave_pos GROUP BY domain_id;
 | |
| 
 | |
| --source include/stop_slave.inc
 | |
| SET GLOBAL gtid_pos_auto_engines="innodb";
 | |
| --source include/start_slave.inc
 | |
| 
 | |
| --connection server_1
 | |
| INSERT INTO t1 VALUES (7);
 | |
| INSERT INTO t2 VALUES (4);
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| --source include/save_master_gtid.inc
 | |
| 
 | |
| --connection server_2
 | |
| --source include/sync_with_master_gtid.inc
 | |
| SELECT * FROM t1 ORDER BY a;
 | |
| SELECT * FROM t2 ORDER BY a;
 | |
| 
 | |
| --echo *** Verify that mysql.gtid_slave_pos_InnoDB is auto-created ***
 | |
| let $wait_condition=
 | |
|   SELECT EXISTS (SELECT * FROM information_schema.tables
 | |
|                   WHERE table_schema='mysql' AND table_name='gtid_slave_pos_InnoDB');
 | |
| --source include/wait_condition.inc
 | |
| SELECT lower(table_name), engine FROM information_schema.tables
 | |
|  WHERE table_schema='mysql' AND table_name LIKE 'gtid_slave_pos%'
 | |
|  ORDER BY table_name;
 | |
| SELECT domain_id, max(seq_no) FROM mysql.gtid_slave_pos GROUP BY domain_id;
 | |
| 
 | |
| # Check that the auto-created InnoDB table starts being used without
 | |
| # needing slave restart. The auto-create happens asynchronously, so it
 | |
| # is non-deterministic when it will start being used. But we can wait
 | |
| # for it to happen.
 | |
| 
 | |
| --let $count=300
 | |
| --let $done=0
 | |
| --let $old_silent= $keep_include_silent
 | |
| --let $keep_include_silent= 1
 | |
| --disable_query_log
 | |
| while (!$done)
 | |
| {
 | |
|   --connection server_1
 | |
|   INSERT INTO t2(a) SELECT 1+MAX(a) FROM t2;
 | |
|   --source include/save_master_gtid.inc
 | |
| 
 | |
|   --connection server_2
 | |
|   --source include/sync_with_master_gtid.inc
 | |
|   --let $done=`SELECT COUNT(*) > 0 FROM mysql.gtid_slave_pos_InnoDB`
 | |
|   if (!$done)
 | |
|   {
 | |
|     dec $count;
 | |
|     if (!$count)
 | |
|     {
 | |
|       SELECT * FROM mysql.gtid_slave_pos_InnoDB;
 | |
|       --die Timeout waiting for mysql.gtid_slave_pos_InnoDB to be used
 | |
|     }
 | |
|     real_sleep 0.1;
 | |
|   }
 | |
| }
 | |
| --enable_query_log
 | |
| --let $keep_include_silent=$old_silent
 | |
| # Note that at this point, the contents of table t2, as well as the GTID
 | |
| # position, is non-deterministic.
 | |
| 
 | |
| # MDEV-15373 engine gtid_slave_pos table name disobeys lower-case-table-names
 | |
| # This snippet verifies that engine gtid_slave_pos table is found,
 | |
| # its data are up-to-date.
 | |
| --write_line wait $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| --connection server_2
 | |
| --shutdown_server
 | |
| --source include/wait_until_disconnected.inc
 | |
| 
 | |
| --echo *** Restart the slave server to prove 'gtid_slave_pos_innodb' autodiscovery ***
 | |
| --append_file $MYSQLTEST_VARDIR/tmp/mysqld.2.expect
 | |
| restart: --skip-slave-start=0
 | |
| EOF
 | |
| 
 | |
| --connection server_2
 | |
| --enable_reconnect
 | |
| --enable_prepare_warnings
 | |
| --source include/wait_until_connected_again.inc
 | |
| --disable_cursor_protocol
 | |
| SELECT max(seq_no) FROM mysql.gtid_slave_pos_InnoDB into @seq_no;
 | |
| --disable_prepare_warnings
 | |
| --enable_cursor_protocol
 | |
| 
 | |
| --connection server_1
 | |
| INSERT INTO t2(a) SELECT 1+MAX(a) FROM t2;
 | |
| --source include/save_master_gtid.inc
 | |
| 
 | |
| --connection server_2
 | |
| --source include/sync_with_master_gtid.inc
 | |
| if (`SELECT  max(seq_no) <> @seq_no + 1  FROM mysql.gtid_slave_pos_InnoDB`)
 | |
| {
 | |
|   SELECT * FROM mysql.gtid_slave_pos_InnoDB;
 | |
|   --die Inconsistent table
 | |
| }
 | |
| #
 | |
| # end of MDEV-15373
 | |
| 
 | |
| #--connection server_2
 | |
| --source include/stop_slave.inc
 | |
| SET GLOBAL gtid_pos_auto_engines="";
 | |
| SET sql_log_bin=0;
 | |
| DROP TABLE mysql.gtid_slave_pos_InnoDB;
 | |
| SET sql_log_bin=1;
 | |
| --source include/start_slave.inc
 | |
| 
 | |
| --connection server_1
 | |
| DROP TABLE t1, t2;
 | |
| 
 | |
| --source include/rpl_end.inc
 | 
