mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 17:08:14 +02:00 
			
		
		
		
	 5ab5ff08b0
			
		
	
	
	5ab5ff08b0
	
	
	
		
			
			This commit makes replicas crash-safe by default by changing the Using_Gtid value to be Slave_Pos on a fresh slave start and after RESET SLAVE is issued. If the primary server does not support GTIDs (i.e., version < 10), the replica will fall back to Using_Gtid=No on slave start and after RESET SLAVE. The following additional informational messages/warnings are added: 1. When Using_Gtid is automatically changed. That is, if RESET SLAVE reverts Using_Gtid back to Slave_Pos, or Using_Gtid is inferred to No from a CHANGE MASTER TO given with log coordinates without MASTER_USE_GTID. 2. If options are ignored in CHANGE MASTER TO. If CHANGE MASTER TO is given with log coordinates, yet also specifies MASTER_USE_GTID=Slave_Pos, a warning message is given that the log coordinate options are ignored. Additionally, an MTR macro has been added for RESET SLAVE, reset_slave.inc, which provides modes/options for resetting a slave in log coordinate or gtid modes. When in log coordinates mode, the macro will execute CHANGE MASTER TO MASTER_USE_GTID=No after the RESET SLAVE command. When in GTID mode, an extra parameter, reset_slave_keep_gtid_state, can be set to reset or preserve the value of gtid_slave_pos. Reviewed By: =========== Andrei Elkin <andrei.elkin@mariadb.com>
		
			
				
	
	
		
			116 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| # TBF - difference in row level logging
 | |
| # Temp tables are not replicated in rbr, but it is still good to hit rbr with everthing
 | |
| 
 | |
| # See SHOW SLAVE STATUS displays well after RESET SLAVE (it should display the
 | |
| # --master-* options from mysqld, as this is what is going to be used next time
 | |
| # slave threads will be started). In bug 985, it displayed old values (of before
 | |
| # RESET SLAVE).
 | |
| # See if slave crashes when doing a CREATE TEMPORARY TABLE twice, separated by
 | |
| # RESET SLAVE.
 | |
| 
 | |
| -- source include/master-slave.inc
 | |
| sync_slave_with_master;
 | |
| --disable_query_log
 | |
| set sql_log_bin=0;
 | |
| call mtr.add_suppression('Slave I/O: Get master BINLOG_CHECKSUM failed with error');
 | |
| set sql_log_bin=1;
 | |
| --enable_query_log
 | |
| let $status_items= Master_User, Master_Host;
 | |
| source include/show_slave_status.inc;
 | |
| 
 | |
| source include/stop_slave.inc;
 | |
| change master to master_user='test';
 | |
| source include/show_slave_status.inc;
 | |
| 
 | |
| --source include/reset_slave.inc
 | |
| source include/show_slave_status.inc;
 | |
| 
 | |
| change master to master_user='root';
 | |
| source include/start_slave.inc;
 | |
| sync_with_master;
 | |
| source include/show_slave_status.inc;
 | |
| 
 | |
| # test of crash with temp tables & RESET SLAVE
 | |
| # (test to see if RESET SLAVE clears temp tables in memory and disk)
 | |
| source include/stop_slave.inc;
 | |
| --source include/reset_slave.inc
 | |
| source include/start_slave.inc;
 | |
| connection master;
 | |
| create temporary table t1 (a int);
 | |
| sync_slave_with_master;
 | |
| source include/stop_slave.inc;
 | |
| --source include/reset_slave.inc
 | |
| source include/start_slave.inc;
 | |
| sync_with_master;
 | |
| show status like 'slave_open_temp_tables';
 | |
| connection master;
 | |
| drop temporary table if exists t1;
 | |
| sync_slave_with_master;
 | |
| 
 | |
| #
 | |
| #Bug#34654  	RESET SLAVE does not clear LAST_IO_Err* 
 | |
| #
 | |
| 
 | |
| # clearing the status
 | |
| source include/stop_slave.inc;
 | |
| --source include/reset_slave.inc
 | |
| source include/check_slave_no_error.inc;
 | |
| 
 | |
| #
 | |
| # verifying start slave resets Last_IO_Error and Last_IO_Errno.
 | |
| #
 | |
| 
 | |
| change master to master_user='impossible_user_name';
 | |
| start slave;
 | |
| let $slave_io_errno= 1045;
 | |
| --source include/wait_for_slave_io_error.inc
 | |
| --source include/stop_slave_sql.inc
 | |
| 
 | |
| change master to master_user='root';
 | |
| source include/start_slave.inc;
 | |
| source include/check_slave_no_error.inc;
 | |
| 
 | |
| #
 | |
| # verifying reset slave resets Last_{IO,SQL}_Err{or,no}
 | |
| #
 | |
| 
 | |
| stop slave;
 | |
| change master to master_user='impossible_user_name';
 | |
| start slave;
 | |
| let $slave_io_errno= 1045;
 | |
| --source include/wait_for_slave_io_error.inc
 | |
| --source include/stop_slave_sql.inc
 | |
| 
 | |
| --source include/reset_slave.inc
 | |
| source include/check_slave_no_error.inc;
 | |
| change master to master_user='root';
 | |
| 
 | |
| 
 | |
| #
 | |
| # BUG#11809016 - NO WAY TO DISCOVER AN INSTANCE IS NO LONGER A SLAVE FOLLOWING MYSQL BUG#28796
 | |
| #
 | |
| 
 | |
| --source include/reset_slave.inc
 | |
| --source include/start_slave.inc
 | |
| 
 | |
| --source include/stop_slave.inc
 | |
| --let $_slave_master_host= query_get_value(SHOW SLAVE STATUS, Master_Host, 1)
 | |
| --let $_slave_master_user= query_get_value(SHOW SLAVE STATUS, Master_User, 1)
 | |
| --let $_slave_master_port= query_get_value(SHOW SLAVE STATUS, Master_Port, 1)
 | |
| 
 | |
| reset slave all;
 | |
| set @@global.gtid_slave_pos= "";
 | |
| --error ER_BAD_SLAVE
 | |
| start slave;
 | |
| 
 | |
| --let $_show_master_host= query_get_value(SHOW SLAVE STATUS, Master_Host, 1)
 | |
| if ($_show_master_host != No such row)
 | |
| {
 | |
|   die;
 | |
| }
 | |
| 
 | |
| --replace_result $_slave_master_host MASTER_HOST $_slave_master_user MASTER_USER $_slave_master_port MASTER_PORT
 | |
| --eval CHANGE MASTER TO MASTER_HOST= '$_slave_master_host', MASTER_USER= '$_slave_master_user', MASTER_PORT= $_slave_master_port
 | |
| --source include/start_slave.inc
 | |
| 
 | |
| --source include/rpl_end.inc
 |