mirror of
https://github.com/MariaDB/server.git
synced 2025-08-07 00:04:31 +03:00
Warnings are added to net_server.cc when global_system_variables.log_warnings >= 4. When the above condition holds then: - All communication errors from net_serv.cc is also written to the error log. - In case of a of not being able to read or write a packet, a more detailed error is given. Other things: - Added detection of slaves that has hangup to Ack_receiver::run() - vio_close() is now first marking the socket closed before closing it. The reason for this is to ensure that the connection that gets a read error can check if the reason was that the socket was closed. - Add a new state to vio to be able to detect if vio is acive, shutdown or closed. This is used to detect if socket is closed by another thread. - Testing of the new warnings is done in rpl_get_lock.test - Suppress some of the new warnings in mtr to allow one to run some of the tests with -mysqld=--log-warnings=4. All test in the 'rpl' suite can now be run with this option. - Ensure that global.log_warnings are restored at test end in a way that allows one to use mtr --mysqld=--log-warnings=4. Reviewed-by: <serg@mariadb.org>,<brandon.nesterenko@mariadb.com>
71 lines
2.2 KiB
Plaintext
71 lines
2.2 KiB
Plaintext
# ==== Purpose ====
|
|
#
|
|
# Test verifies that, due to a temporary network error, if request dump
|
|
# command specific packet write operation fails then the write error gets
|
|
# handled appropriately. Further retry will be initiated with appropriate
|
|
# slave registration on master. This will ensure that master has all the
|
|
# details of slave and no warnings are reported on the master side.
|
|
#
|
|
# ==== Implementation ====
|
|
#
|
|
# Steps:
|
|
# 0 - Skip the slave start.
|
|
# 1 - Enable debug simulation which will simulate packet write error during
|
|
# dump request command execution.
|
|
# 2 - Start the slave. Observe that slave is able to reconnect post
|
|
# temporary network write error.
|
|
#
|
|
# ==== References ====
|
|
#
|
|
# MDEV-14203: rpl.rpl_extra_col_master_myisam,
|
|
# rpl.rpl_slave_load_tmpdir_not_exist failed in buildbot with a
|
|
# warning
|
|
#
|
|
# MDEV-13258: rpl.rpl_skip_replication, rpl.rpl_set_statement_default_master
|
|
# failed in buildbot
|
|
#
|
|
|
|
--source include/have_debug.inc
|
|
--source include/have_debug_sync.inc
|
|
--let $rpl_skip_start_slave=1
|
|
--source include/master-slave.inc
|
|
|
|
--disable_query_log
|
|
call mtr.add_suppression("Could not read packet:.* errno: 11");
|
|
--enable_query_log
|
|
|
|
# Do an insert on master
|
|
CREATE TABLE t1(a int);
|
|
INSERT INTO t1 VALUES(1);
|
|
|
|
# Add a debug point and start the slave so that dump request fails.
|
|
connection slave;
|
|
SET @saved_dbug = @@GLOBAL.debug_dbug;
|
|
SET @@global.debug_dbug= 'd,simulate_error_on_packet_write';
|
|
|
|
START SLAVE;
|
|
SET DEBUG_SYNC= 'now WAIT_FOR parked';
|
|
SET @@GLOBAL.debug_dbug = @saved_dbug;
|
|
SET DEBUG_SYNC= 'now SIGNAL continue';
|
|
|
|
# Ensure the last DEBUG_SYNC signal was received by the target thread before
|
|
# reset; otherwise, the reset can drop the last signal before it gets
|
|
# acknowledged
|
|
let $wait_condition= select count(*)=0 from information_schema.processlist where state like "%debug%";
|
|
source include/wait_condition.inc;
|
|
SET DEBUG_SYNC= 'RESET';
|
|
|
|
--source include/wait_for_slave_io_to_start.inc
|
|
--source include/wait_for_slave_sql_to_start.inc
|
|
|
|
# Sync the slave and verify that slave has caught up with the master.
|
|
connection master;
|
|
--source include/sync_slave_sql_with_master.inc
|
|
SELECT * FROM t1;
|
|
|
|
# Cleanup
|
|
connection master;
|
|
DROP TABLE t1;
|
|
|
|
--source include/rpl_end.inc
|