gbichot@dl145h.mysql.com
ba2452f092
Fix for BUG#25628: "mysqlbinlog crashes while processing binary logs".
...
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.
2007-02-23 22:23:54 +01:00
..
2006-12-31 01:32:21 +01:00
2006-12-31 12:41:42 +04:00
2006-12-31 02:29:11 +01:00
2006-12-31 01:02:27 +01:00
2007-01-17 19:32:14 +01:00
2006-12-31 02:29:11 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2007-01-02 14:18:13 -07:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2007-01-02 14:18:13 -07:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-23 20:20:40 +01:00
2007-01-31 17:01:28 +04:00
2007-01-17 19:32:14 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:02:27 +01:00
2006-12-23 20:17:15 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:04:59 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 14:16:34 +01:00
2006-12-27 11:01:54 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2007-01-17 19:32:14 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2007-01-10 14:14:22 +04:00
2007-01-10 14:14:22 +04:00
2007-01-12 12:31:44 +01:00
2006-12-31 01:32:21 +01:00
2007-01-12 22:06:46 +03:00
2007-01-10 14:14:22 +04:00
2006-12-31 01:32:21 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 12:41:42 +04:00
2006-12-23 20:20:40 +01:00
2007-01-08 12:32:48 +02:00
2007-01-08 12:32:48 +02:00
2006-12-23 20:20:40 +01:00
2007-01-12 08:11:52 -07:00
2007-01-12 12:31:44 +01:00
2006-12-31 01:32:21 +01:00
2007-01-22 13:28:58 +04:00
2006-12-27 02:23:51 +01:00
2007-01-12 14:48:59 +04:00
2007-01-12 08:11:52 -07:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2007-01-12 08:11:52 -07:00
2007-01-02 14:18:13 -07:00
2007-02-23 22:23:54 +01:00
2007-02-23 22:23:54 +01:00
2007-02-23 14:59:48 +01:00
2007-01-12 12:31:44 +01:00
2007-01-12 08:11:52 -07:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2007-01-18 18:23:25 -05:00
2006-12-23 20:17:15 +01:00
2007-02-15 16:05:22 +01:00
2006-11-16 14:38:45 +02:00
2006-12-23 20:20:40 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 02:29:11 +01:00
2006-12-27 02:23:51 +01:00
2006-12-31 02:29:11 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2007-01-12 12:31:44 +01:00
2007-01-12 12:31:44 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-27 02:23:51 +01:00
2006-12-31 02:29:11 +01:00
2007-01-26 20:56:49 +01:00
2007-01-17 19:32:14 +01:00
2007-01-17 19:32:14 +01:00
2007-02-23 22:00:45 +01:00
2007-02-23 18:54:26 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:17:15 +01:00
2007-01-17 19:32:14 +01:00
2007-01-17 19:32:14 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 01:32:21 +01:00
2007-01-12 12:31:44 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-23 20:17:15 +01:00
2007-01-17 19:32:14 +01:00
2006-12-31 02:29:11 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 02:29:11 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 01:02:27 +01:00
2007-01-17 19:32:14 +01:00
2007-01-17 19:32:14 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 01:32:21 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2007-02-23 14:59:48 +01:00
2007-01-17 19:32:14 +01:00
2007-01-17 19:32:14 +01:00
2006-12-31 01:02:27 +01:00
2007-01-15 13:10:07 +03:00
2007-01-12 12:31:44 +01:00
2007-01-12 12:31:44 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2007-01-17 19:32:14 +01:00
2006-10-17 19:54:44 +03:00
2007-01-10 16:23:54 +04:00
2006-12-27 02:23:51 +01:00
2006-12-31 01:04:59 +01:00
2006-12-27 02:23:51 +01:00
2007-01-11 22:15:20 +03:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:32:21 +01:00
2007-01-15 13:48:07 +03:00
2006-12-31 01:32:21 +01:00
2006-12-27 02:23:51 +01:00
2006-12-31 02:29:11 +01:00
2007-01-23 14:37:12 +04:00
2006-12-31 02:29:11 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:17:15 +01:00
2007-01-15 23:51:52 +03:00
2006-12-23 20:20:40 +01:00
2007-01-15 13:10:07 +03:00
2006-12-27 02:23:51 +01:00
2006-12-31 01:32:21 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2007-01-08 12:32:48 +02:00
2006-12-31 01:02:27 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 01:32:21 +01:00
2007-01-12 12:31:44 +01:00
2006-12-23 20:20:40 +01:00
2007-01-15 13:10:07 +03:00
2006-12-27 02:23:51 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:20:40 +01:00
2006-12-31 01:32:21 +01:00
2007-01-17 19:32:14 +01:00
2006-10-17 19:54:44 +03:00
2006-12-31 01:32:21 +01:00
2006-12-31 01:02:27 +01:00
2006-12-31 01:32:21 +01:00
2006-12-23 20:17:15 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:20:40 +01:00
2006-12-23 20:17:15 +01:00
2006-11-16 16:19:29 +01:00
2006-12-23 20:17:15 +01:00
2007-01-12 11:06:38 +01:00
2006-12-31 01:32:21 +01:00