403Webshell
Server IP : 172.67.216.182  /  Your IP : 172.70.92.223
Web Server : Apache
System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64
User : www ( 1000)
PHP Version : 7.4.33
Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : ON
Directory :  /www/server/mysql/src/mysql-test/suite/rpl/t/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /www/server/mysql/src/mysql-test/suite/rpl/t/rpl_flush_logs.test
#
# WL#5142
# This test verifies if the 'flush individual logs' statement 
# works fine.  
#

# "Flush" commands are logged as rotate events in the binary
# log without gtid events. So it is correct to check master
# and slave sync logic with positions instead gtids numbers.
# Hence for this test script, making use_gtids to false
# in all the cases (GTID_MODE ON or OFF).
--let $use_gtids=0

--source include/master-slave.inc
--source include/have_binlog_format_statement.inc
connection master;

# Test 'flush error logs' statement.

--echo # Test if support 'flush error logs' statement.
flush error logs;

file_exists $MYSQLTEST_VARDIR/tmp/master_log.err;

--echo # Make sure binary logs was not be flushed
--echo # after execute 'flush error logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000002;

--source include/sync_slave_sql_with_master.inc
--echo # Make sure relay logs was not be flushed 
--echo # after execute 'flush error logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000003;

connection master;
--echo # Test if support 'flush relay logs' statement.
flush relay logs;

--source include/sync_slave_sql_with_master.inc
--echo # Check the 'slave-relay-bin.000003' file is created
--echo # after executed 'flush relay logs' statement.
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000003;

connection master;
--echo # Make sure binary logs was not be flushed
--echo # after execute 'flush relay logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000002;


# Test 'flush slow logs' statement.
--echo # Test if support 'flush slow logs' statement.
flush slow logs;

--echo # Make sure binary logs was not be flushed
--echo # after execute 'flush slow logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000002;


# Test 'flush general logs' statement.
--echo # Test if support 'flush general logs' statement.
flush general logs;

--echo # Make sure binary logs was not be flushed
--echo # after execute 'flush general logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000002;


# Test 'flush engine logs' statement.
--echo # Test if support 'flush engine logs' statement.
flush engine logs;

--echo # Make sure binary logs was not be flushed
--echo # after execute 'flush engine logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000002;


# Test 'flush binary logs' statement.
--echo # Make sure the 'master-bin.000002' file does not
--echo # exist before execute 'flush binary logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000002;

--echo # Test if support 'flush binary logs' statement.
flush binary logs;

--echo # Check the 'master-bin.000002' file is created
--echo # after executed 'flush binary logs' statement.
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000002;
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000001;


# Test 'flush error logs, relay logs' statement
--source include/sync_slave_sql_with_master.inc
--echo # Make sure the 'slave-relay-bin.000006' file does not exist
--echo # exist before execute 'flush error logs, relay logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000006;

connection master;

--echo # Test if support to combine all kinds of logs into one statement.
flush error logs, relay logs;

file_exists $MYSQLTEST_VARDIR/tmp/master_log.err;

--echo # Make sure binary logs was not be flushed
--echo # after execute 'flush error logs, relay logs' statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000003;

--source include/sync_slave_sql_with_master.inc
--echo # Check the 'slave-relay-bin.000006' file is created after
--echo # execute 'flush error logs, relay logs' statement.
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000006;


# Test 'flush logs' statement
--echo # Make sure the 'slave-relay-bin.000007' and 'slave-relay-bin.000008'
--echo # files do not exist before execute 'flush error logs, relay logs'
--echo # statement.
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000007;
--error 1
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000008;

--source include/stop_slave_sql.inc

connection master;

--echo # Test if 'flush logs' statement works fine and flush all the logs.
flush logs;

file_exists $MYSQLTEST_VARDIR/tmp/master_log.err;

--echo # Check 'master-bin.000003' is created
--echo # after execute 'flush logs' statement.
file_exists $MYSQLTEST_VARDIR/mysqld.1/data/master-bin.000003;

--source include/sync_slave_io_with_master.inc
--echo # Check the 'slave-relay-bin.000007' and 'slave-relay-bin.000008'
--echo # files are created after execute 'flush logs' statement.
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000007;
file_exists $MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.000008;

#
# Bug #24786290: REPLICATION BREAKS AFTER BUG #74145 HAPPENS IN MASTER
#
# === Purpose ===
#
# This test verifies that failed FLUSH <individual> LOGS statements
# are not written to binary log.

--connection master
--let $binlog_file= query_get_value(SHOW MASTER STATUS,File,1)
--let $binlog_start= query_get_value(SHOW MASTER STATUS,Position,1)
--let $master_pos_before_flush_logs= $binlog_start

# Make FLUSH <individual> LOGS fail by changing
# the permissions of the slow log and general log.
--let $slow_log= `SELECT @@global.slow_query_log_file`
--chmod 0000 $slow_log
--replace_regex /.*File .* not found .*/File not found (Errcode: ##)/
--error 29
FLUSH SLOW LOGS;

--let $general_log= `SELECT @@global.general_log_file`
--chmod 0000 $general_log
--replace_regex /.*File .* not found .*/File not found (Errcode: ##)/
--error 29
FLUSH GENERAL LOGS;

# Assert that the above statements are not written to the binlog.
--let $master_pos_after_flush_logs= query_get_value(SHOW MASTER STATUS,Position,1)
--let $assert_text= assert that the above events are not written to binlog
--let $assert_cond= $master_pos_before_flush_logs = $master_pos_after_flush_logs
--source include/assert.inc
--source include/show_binlog_events.inc

# Restore permissions
--chmod 0644 $slow_log
--chmod 0644 $general_log

--source include/sync_slave_io_with_master.inc
--source include/start_slave_sql.inc
--source include/rpl_end.inc

Youez - 2016 - github.com/yon3zu
LinuXploit