2001-06-21 13:19:24 -06:00
|
|
|
source include/master-slave.inc;
|
|
|
|
|
2003-02-21 23:38:56 +01:00
|
|
|
# Clean up old slave's binlogs.
|
|
|
|
# The slave is started with --log-slave-updates
|
|
|
|
# and this test does SHOW BINLOG EVENTS on the slave's
|
|
|
|
# binlog. But previous tests can influence the current test's
|
|
|
|
# binlog (e.g. a temporary table in the previous test has not
|
|
|
|
# been explicitly deleted, and at the beginning of the current
|
|
|
|
# test the slave immediately writes DROP TEMPORARY TABLE this_old_table).
|
|
|
|
# We wait for the slave to have written all he wants to the binlog
|
|
|
|
# (otherwise RESET MASTER may come too early).
|
|
|
|
save_master_pos;
|
2001-06-21 13:19:24 -06:00
|
|
|
connection slave;
|
2003-02-21 23:38:56 +01:00
|
|
|
sync_with_master;
|
2002-10-24 17:46:14 -06:00
|
|
|
stop slave;
|
2001-06-21 13:19:24 -06:00
|
|
|
reset master;
|
2001-06-22 08:35:18 -06:00
|
|
|
reset slave;
|
Result updates after Dmitri's and my changes to logging with --log-slave-updates.
Since my changes, rpl_log.test, whose result file depends on file_id, became
non-repeatable, i.e. file_id on slave in SHOW BINLOG EVENTS
changed depending on the order of tests (sometimes 1, sometimes 5).
Which is logical: as now the slave does not copy Create_file and Exec_load from
the relay log (i.e from the master's binlog) to the slave's binlog, but
instead lets mysql_load() do the logging, the file_id is now the one whic
was used on the slave. Before it was the one which was used on the master,
and by chance the master was always restarted for this test because there's
a -master.opt file, so file_id on the master is always 1. But now file_id is
from the slave so we need to restart the slave. That's why I add an (empty)
-slave.opt file. I could have used 'server_stop/start slave', but this
would have required the manager, so most of the time mysql-test-run silently
skip the test which makes it useless. And I want this test to be run !
2003-08-21 00:23:39 +02:00
|
|
|
# We are going to read the slave's binlog which contains file_id (for some LOAD
|
|
|
|
# DATA INFILE); to make it repeatable (not influenced by other tests), we need
|
|
|
|
# to stop and start the slave, to be sure file_id will start from 1.
|
|
|
|
# This can be done with 'server_stop slave', but
|
|
|
|
# this would require the manager, so most of the time the test will be skipped
|
|
|
|
# :(
|
|
|
|
# To workaround this, I (Guilhem) add a (empty) rpl_log-slave.opt (because when
|
|
|
|
# mysql-test-run finds such a file it restarts the slave before doing the
|
|
|
|
# test). That's not very elegant but I could find no better way, sorry.
|
|
|
|
|
2001-12-15 04:41:20 +02:00
|
|
|
let $VERSION=`select version()`;
|
2001-06-21 13:19:24 -06:00
|
|
|
|
|
|
|
connection master;
|
2001-06-22 08:35:18 -06:00
|
|
|
reset master;
|
2001-06-21 13:19:24 -06:00
|
|
|
create table t1(n int not null auto_increment primary key);
|
|
|
|
insert into t1 values (NULL);
|
|
|
|
drop table t1;
|
|
|
|
create table t1 (word char(20) not null);
|
2003-08-10 05:14:16 +03:00
|
|
|
load data infile '../../std_data/words.dat' into table t1 ignore 1 lines;
|
|
|
|
select count(*) from t1;
|
2001-06-21 13:19:24 -06:00
|
|
|
drop table t1;
|
2001-12-15 04:41:20 +02:00
|
|
|
--replace_result $VERSION VERSION
|
2001-06-21 13:19:24 -06:00
|
|
|
show binlog events;
|
2005-03-16 04:32:47 +03:00
|
|
|
show binlog events from 98 limit 1;
|
|
|
|
show binlog events from 98 limit 2;
|
|
|
|
show binlog events from 98 limit 2,1;
|
2001-06-21 13:19:24 -06:00
|
|
|
flush logs;
|
2002-09-11 06:40:08 +03:00
|
|
|
|
2003-05-27 23:07:32 +02:00
|
|
|
# We need an extra update before doing save_master_pos.
|
|
|
|
# Otherwise, an unlikely scenario may occur:
|
|
|
|
# * When the master's binlog_dump thread reads the end of master-bin.001,
|
|
|
|
# it send the rotate event which is at this end, plus a fake rotate event
|
|
|
|
# because it's starting to read a new binlog.
|
|
|
|
# save_master_pos will record the position of the first of the two rotate
|
|
|
|
# (because the fake one is not in the master's binlog anyway).
|
|
|
|
# * Later the slave waits for the position of the first rotate event,
|
|
|
|
# and it may quickly stop (in 'slave stop') without having received the fake
|
|
|
|
# one.
|
|
|
|
# So, depending on a few milliseconds, we end up with 2 rotate events in the
|
|
|
|
# relay log or one, which influences the output of SHOW SLAVE STATUS, making
|
|
|
|
# it not predictable and causing random test failures.
|
2003-08-10 05:14:16 +03:00
|
|
|
# To make it predictable, we do a useless update now, but which has the
|
|
|
|
# interest of making the slave catch both rotate events.
|
2003-05-27 23:07:32 +02:00
|
|
|
|
|
|
|
create table t5 (a int);
|
|
|
|
drop table t5;
|
|
|
|
|
2002-09-11 06:40:08 +03:00
|
|
|
# Sync slave and force it to start on another binary log
|
|
|
|
|
|
|
|
save_master_pos;
|
|
|
|
connection slave;
|
2003-05-27 23:07:32 +02:00
|
|
|
# Note that the above 'slave start' will cause a 3rd rotate event (a fake one)
|
|
|
|
# to go into the relay log (the master always sends a fake one when replication
|
|
|
|
# starts).
|
2003-06-04 23:17:01 +03:00
|
|
|
start slave;
|
2002-09-11 06:40:08 +03:00
|
|
|
sync_with_master;
|
|
|
|
flush logs;
|
2002-10-24 17:46:14 -06:00
|
|
|
stop slave;
|
2002-09-11 06:40:08 +03:00
|
|
|
connection master;
|
|
|
|
|
|
|
|
# Create some entries for second log
|
|
|
|
|
2001-06-23 19:37:24 -06:00
|
|
|
create table t1 (n int);
|
|
|
|
insert into t1 values (1);
|
|
|
|
drop table t1;
|
2001-12-15 04:41:20 +02:00
|
|
|
--replace_result $VERSION VERSION
|
2001-06-21 13:19:24 -06:00
|
|
|
show binlog events;
|
2003-12-19 22:40:23 +01:00
|
|
|
--replace_result $VERSION VERSION
|
2002-10-29 15:11:13 -07:00
|
|
|
show binlog events in 'master-bin.000002';
|
2002-10-24 18:32:42 -06:00
|
|
|
show binary logs;
|
2001-06-21 13:19:24 -06:00
|
|
|
save_master_pos;
|
|
|
|
connection slave;
|
2002-10-24 17:46:14 -06:00
|
|
|
start slave;
|
2001-06-21 13:19:24 -06:00
|
|
|
sync_with_master;
|
2002-10-24 18:32:42 -06:00
|
|
|
show binary logs;
|
2004-05-10 12:15:40 +02:00
|
|
|
--replace_result $MASTER_MYPORT MASTER_PORT $VERSION VERSION
|
2002-10-29 15:11:13 -07:00
|
|
|
show binlog events in 'slave-bin.000001' from 4;
|
2004-05-10 12:15:40 +02:00
|
|
|
--replace_result $MASTER_MYPORT MASTER_PORT $VERSION VERSION
|
2002-10-29 15:11:13 -07:00
|
|
|
show binlog events in 'slave-bin.000002' from 4;
|
2004-05-10 12:15:40 +02:00
|
|
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
2003-12-19 22:40:23 +01:00
|
|
|
--replace_column 1 # 8 # 9 # 23 # 33 #
|
2001-06-23 19:37:24 -06:00
|
|
|
show slave status;
|
2002-09-11 06:40:08 +03:00
|
|
|
|
|
|
|
# Need to recode the following
|
|
|
|
|
2002-10-29 15:11:13 -07:00
|
|
|
#show new master for slave with master_log_file='master-bin.000001' and master_log_pos=4 and master_server_id=1;
|
|
|
|
#show new master for slave with master_log_file='master-bin.000001' and master_log_pos=79 and master_server_id=1;
|
|
|
|
#show new master for slave with master_log_file='master-bin.000001' and master_log_pos=311 and master_server_id=1;
|
|
|
|
#show new master for slave with master_log_file='master-bin.000002' and master_log_pos=4 and master_server_id=1;
|
|
|
|
#show new master for slave with master_log_file='master-bin.000002' and master_log_pos=122 and master_server_id=1;
|
2002-09-11 06:40:08 +03:00
|
|
|
|
|
|
|
--error 1220
|
2002-10-29 15:11:13 -07:00
|
|
|
show binlog events in 'slave-bin.000005' from 4;
|