mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-24 07:13:33 +03:00 
			
		
		
		
	 ba2452f092
			
		
	
	ba2452f092
	
	
	
		
			
			mysqlbinlog prints all row-based events of a single statement as a single "BINLOG" statement containing the concatenation of those events. Big (i.e. >64k) concatenations of row-based events (e.g. Write_rows_log_event) caused mysqlbinlog's IO_CACHE to overflow to a temporary file but the IO_CACHE had not been inited with open_cached_file(), so it tried to create a temporary file in an uninitialized directory (thus failing to create, then to write; some OS errors were printed, and it finally segfaulted). After fixing this, it appeared that mysqlbinlog was printing only a piece of big concatenations of row-based events (it printed at most the size of the IO_CACHE's buffer i.e. 64k); that caused data loss at restore. We fix and test that. Last, mysqlbinlog's printouts looked a bit strange with the informative header (#-prefixed) of groupped Rows_log_event all on one line, so we insert \n. After that, a small bug in the --hexdump code appeared (only if the string to hex-print had its length a multiple of 16), we fix it.
		
			
				
	
	
		
			68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| -- source include/have_binlog_format_row.inc
 | |
| #
 | |
| #  Write different events to binlog
 | |
| #
 | |
| create table t1 (a int);
 | |
| insert into t1 values (1);
 | |
| insert into t1 values (2);
 | |
| insert into t1 values (3);
 | |
| update t1 set a=a+2 where a=2;
 | |
| update t1 set a=a+2 where a=3;
 | |
| 
 | |
| create table t2 (word varchar(20));
 | |
| load data infile '../std_data_ln/words.dat' into table t2;
 | |
| 
 | |
| #
 | |
| #  Save binlog
 | |
| #
 | |
| flush logs;
 | |
| --exec $MYSQL_BINLOG --hexdump $MYSQLTEST_VARDIR/log/master-bin.000001 > $MYSQLTEST_VARDIR/tmp/mysqlbinlog_base64.sql
 | |
| 
 | |
| #
 | |
| #  Clear database and restore from binlog
 | |
| #
 | |
| drop table t1;
 | |
| drop table t2;
 | |
| --exec $MYSQL test < $MYSQLTEST_VARDIR/tmp/mysqlbinlog_base64.sql
 | |
| 
 | |
| #
 | |
| #  Verify that all binlog events have been executed
 | |
| #
 | |
| select * from t1;
 | |
| select * from t2;
 | |
| 
 | |
| #
 | |
| #  Verify that events larger than the default IO_CACHE buffer
 | |
| #  are handled correctly (BUG#25628).
 | |
| #
 | |
| flush logs;
 | |
| drop table t2;
 | |
| create table t2 (word varchar(20));
 | |
| load data infile '../std_data_ln/words.dat' into table t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| insert into t2 select * from t2;
 | |
| select count(*) from t2;
 | |
| 
 | |
| flush logs;
 | |
| --exec $MYSQL_BINLOG --hexdump $MYSQLTEST_VARDIR/log/master-bin.000003 > $MYSQLTEST_VARDIR/tmp/mysqlbinlog_base64.sql
 | |
| --exec $MYSQL test < $MYSQLTEST_VARDIR/tmp/mysqlbinlog_base64.sql
 | |
| 
 | |
| #
 | |
| #  Verify that all binlog events have been executed
 | |
| #
 | |
| select count(*) from t2;
 | |
| 
 | |
| #
 | |
| #  Test cleanup
 | |
| #
 | |
| --exec rm $MYSQLTEST_VARDIR/tmp/mysqlbinlog_base64.sql
 | |
| drop table t1;
 | |
| drop table t2;
 |