MariaDB server is a community developed fork of MySQL server. Started by core members of the original MySQL team, MariaDB actively works with outside developers to deliver the most featureful, stable, and sanely licensed open SQL server in the industry.
Find a file
Andrei Elkin 5d48ea7d07 MDEV-10963 Fragmented BINLOG query
The problem was originally stated in
  http://bugs.mysql.com/bug.php?id=82212
The size of an base64-encoded Rows_log_event exceeds its
vanilla byte representation in 4/3 times.
When a binlogged event size is about 1GB mysqlbinlog generates
a BINLOG query that can't be send out due to its size.

It is fixed with fragmenting the BINLOG argument C-string into
(approximate) halves when the base64 encoded event is over 1GB size.
The mysqlbinlog in such case puts out

    SET @binlog_fragment_0='base64-encoded-fragment_0';
    SET @binlog_fragment_1='base64-encoded-fragment_1';
    BINLOG @binlog_fragment_0, @binlog_fragment_1;

to represent a big BINLOG.
For prompt memory release BINLOG handler is made to reset the BINLOG argument
user variables in the middle of processing, as if @binlog_fragment_{0,1} = NULL
is assigned.

Notice the 2 fragments are enough, though the client and server still may
need to tweak their @@max_allowed_packet to satisfy to the fragment
size (which they would have to do anyway with greater number of
fragments, should that be desired).

On the lower level the following changes are made:

Log_event::print_base64()
  remains to call encoder and store the encoded data into a cache but
  now *without* doing any formatting. The latter is left for time
  when the cache is copied to an output file (e.g mysqlbinlog output).
  No formatting behavior is also reflected by the change in the meaning
  of the last argument which specifies whether to cache the encoded data.

Rows_log_event::print_helper()
  is made to invoke a specialized fragmented cache-to-file copying function
  which is

copy_cache_to_file_wrapped()
  that takes care of fragmenting also optionally wraps encoded
  strings (fragments) into SQL stanzas.

my_b_copy_to_file()
  is refactored to into my_b_copy_all_to_file(). The former function
  is generalized
  to accepts more a limit argument to constraint the copying and does
  not reinitialize anymore the cache into reading mode.
  The limit does not do any effect on the fully read cache.
2019-01-24 20:44:50 +02:00
BUILD Updated check-cpu from 10.3 to get it to work with gcc 7.3.1 2018-11-16 14:19:58 +02:00
client MDEV-10963 Fragmented BINLOG query 2019-01-24 20:44:50 +02:00
cmake Merge branch '10.0' into 10.1 2018-12-29 23:44:45 +01:00
dbug MDEV-11752 Unsafe strmov - function definition in include/m_string.h 2017-03-10 18:21:29 +01:00
debian debian install/upgrade fixes 2018-12-12 20:19:56 +01:00
Docs Grammatical errors of README-wsrep fixed. (#915) 2018-12-22 13:34:50 +04:00
extra MDEV-18347: mariabackup doesn't read all server option groups from configuration files 2019-01-24 12:44:55 +01:00
include MDEV-10963 Fragmented BINLOG query 2019-01-24 20:44:50 +02:00
libmysql Bug #26275510 BUNDLED ZLIB DOESN'T INCLUDE FIXES FOR SOME VULNERABILITIES 2018-07-09 17:25:49 +05:30
libmysqld Merge 10.0 into 10.1 2019-01-24 13:24:13 +02:00
libservices MDEV-11663 Create services for functionality used by plugins 2017-04-27 19:12:38 +02:00
man MDEV-14927: Missing man pages 2018-08-28 14:12:42 +03:00
mysql-test MDEV-10963 Fragmented BINLOG query 2019-01-24 20:44:50 +02:00
mysys MDEV-10963 Fragmented BINLOG query 2019-01-24 20:44:50 +02:00
mysys_ssl MDEV-14343 Server crash on FIPS with openssl-1.0.2k 2018-01-30 21:28:16 +01:00
pcre Merge branch '10.0' into 10.1 2018-05-05 14:01:59 +02:00
plugin auth_gssapi : Fix string formatting in my_printf_error() 2018-10-16 09:19:03 +01:00
randgen/conf Group commit for maria engine. 2010-02-12 15:12:28 +02:00
scripts MDEV-17973: Don't overwrite xtrabackup-v2/mariabackup SST logs by default 2019-01-21 05:42:00 -05:00
sql MDEV-10963 Fragmented BINLOG query 2019-01-24 20:44:50 +02:00
sql-bench fix sql-bench test-table-elimination view leak. see MDEV-10310 for details 2016-07-12 22:21:49 +02:00
sql-common Merge branch '10.0' into 10.1 2018-07-31 11:58:29 +02:00
storage Merge 10.0 into 10.1 2019-01-23 14:34:23 +02:00
strings Merge 10.0 into 10.1 2018-11-05 12:15:17 +02:00
support-files Revert commit b2f39a5f56 wrong 2018-11-01 09:27:59 +02:00
tests MDEV-14265 - RPMLint warning: shared-lib-calls-exit 2018-03-16 13:26:52 +04:00
unittest MDEV-10963 Fragmented BINLOG query 2019-01-24 20:44:50 +02:00
vio Merge branch '10.0' into 10.1 2017-09-19 12:06:50 +03:00
win Merge branch 'github/10.0' into 10.1 2018-02-02 10:09:44 +01:00
wsrep Correct FSF address 2017-03-10 18:21:29 +01:00
zlib Bug #26275510 BUNDLED ZLIB DOESN'T INCLUDE FIXES FOR SOME VULNERABILITIES 2018-07-09 17:25:49 +05:30
.gitattributes Merge branch '10.0' into 10.1 2018-05-05 14:01:59 +02:00
.gitignore Merge branch '10.0' into 10.1 2018-10-30 15:10:01 +01:00
BUILD-CMAKE various documentation updates 2012-06-18 16:57:58 -04:00
CMakeLists.txt Merge branch '10.0' into 10.1 2018-10-30 15:10:01 +01:00
config.h.cmake compiler warnings (clang 4.0.1 on i386) 2018-09-04 09:19:48 +02:00
configure.cmake cmake: fix ucontext detection 2018-10-17 00:10:18 +04:00
COPYING Use a new version of "COPYING", the GPL text. 2010-03-04 14:26:27 +01:00
COPYING.thirdparty Correct FSF address 2017-03-10 18:21:29 +01:00
CREDITS Update contributors 2018-09-10 16:47:44 +04:00
EXCEPTIONS-CLIENT MDEV-5645 MariaDB-5.5.35 - references are made to an "EXCEPTIONS-CLIENT" file but it does not exist 2014-05-31 13:18:56 +02:00
INSTALL-SOURCE Update AskMonty and Atlassian references to MariaDB 2016-03-08 15:24:01 +02:00
INSTALL-WIN-SOURCE Update AskMonty and Atlassian references to MariaDB 2016-03-08 15:24:01 +02:00
KNOWN_BUGS.txt various documentation updates 2012-06-18 16:57:58 -04:00
README README: Add reporting security vulns. direction 2018-10-30 13:32:15 +01:00
VERSION bump the VERSION 2018-11-02 12:27:38 -04:00

MariaDB is designed as a drop-in replacement of MySQL(R) with more
features, new storage engines, fewer bugs, and better performance.

MariaDB is brought to you by the MariaDB Foundation.
Please read the CREDITS file for details about the MariaDB Foundation,
and who is developing MariaDB.

MariaDB is developed by many of the original developers of MySQL who
now work for the MariadB Foundation and the MariaDB Corporation, and by many people in
the community.

MySQL, which is the base of MariaDB, is a product and trademark of Oracle
Corporation, Inc. For a list of developers and other contributors,
see the Credits appendix.  You can also run 'SHOW authors' to get a
list of active contributors.

A description of the MariaDB project and a manual can be found at:
http://mariadb.org/
https://mariadb.com/kb/en/
https://mariadb.com/kb/en/mariadb-vs-mysql-features/
https://mariadb.com/kb/en/mariadb-versus-mysql-features/
https://mariadb.com/kb/en/mariadb-versus-mysql-compatibility/

As MariaDB is a full replacement of MySQL, the MySQL manual at
http://dev.mysql.com/doc is generally applicable.

More help is available from the Maria Discuss mailing list
https://launchpad.net/~maria-discuss
and the #maria IRC channel on Freenode.

***************************************************************************

NOTE: 

MariaDB is specifically available only under version 2 of the GNU
General Public License (GPLv2). (I.e. Without the "any later version"
clause.) This is inherited from MySQL. Please see the README file in
the MySQL distribution for more information.

License information can be found in the COPYING, COPYING.LESSER,
and COPYING.thirdparty files.

***************************************************************************

IMPORTANT:

Bug and/or error reports regarding MariaDB should be submitted at:
https://jira.mariadb.org

For reporting security vulnerabilities see:
https://mariadb.org/about/security-policy/

Bugs in the MySQL code can also be submitted at:
http://bugs.mysql.com

The code for MariaDB, including all revision history, can be found at:
https://github.com/MariaDB/server

***************************************************************************