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
Kristian Nielsen b8f9f796ff MDEV-31273: Precompute binlog checksums
Compute binlog checksums (when enabled) already when writing events
into the statement or transaction caches, where before it was done
when the caches are copied to the real binlog file. This moves the
checksum computation outside of holding LOCK_log, improving
scalabitily.

At stmt/trx cache write time, the final end_log_pos values are not
known, so with this patch these will be set to 0. Events that are
written directly to the binlog file (not through stmt/trx cache) keep
the correct end_log_pos value. The GTID and COMMIT/XID events at the
start and end of event groups are written directly, so the zero
end_log_pos is only for events in the middle of event groups, which
do not negatively affect replication.

An option --binlog-legacy-event-pos, off by default, is provided to
disable this behavior to provide backwards compatibility with any
external applications that might rely on end_log_pos in events in the
middle of event groups.

Checksums cannot be pre-computed when binlog encryption is enabled, as
encryption relies on correct end_log_pos to provide part of the
nonce/IV.

Checksum pre-computation is also disabled for WSREP/Galera, as it uses
events differently in its write-sets and so on. Extending pre-computation of
checksums to Galera where it makes sense could be added in a future patch.

The current --binlog-checksum configuration is saved in
binlog_cache_data at transaction start and used to pre-compute
checksums in cache, if applicable. When the cache is later copied to
the binlog, a check is made if the saved value still matches the
configured global value; if so, the events are block-copied directly
into the binlog file. If --binlog-checksum was changed during the
transaction, events are re-written to the binlog file one-by-one and
the checksums recomputed/discarded as appropriate.

Reviewed-by: Monty <monty@mariadb.org>
Signed-off-by: Kristian Nielsen <knielsen@knielsen-hq.org>
2023-10-27 19:57:43 +02:00
.github Merge 10.11 into 11.0 2023-06-08 13:49:48 +03:00
BUILD Merge 10.11 into 11.0 2023-06-28 09:19:19 +03:00
client Merge branch '11.2' into 11.3 2023-09-21 14:15:04 +04:00
cmake MDEV-32252 addendum - refactor CPackWixConfig.cmake 2023-10-04 09:30:01 +02:00
dbug Merge 10.6 into 10.8 2023-02-10 13:43:53 +02:00
debian 11.4 branch 2023-10-09 13:43:10 +02:00
Docs Fixed some typos in optimizer_costs.txt 2023-03-28 18:41:09 +11:00
extra Merge branch '11.2' into 11.3 2023-09-21 14:15:04 +04:00
include MDEV-31273: Precompute binlog checksums 2023-10-27 19:57:43 +02:00
libmariadb@c0ddc2c8cf New CC 3.3 2023-08-01 16:40:10 +02:00
libmysqld Merge branch '11.2' into 11.3 2023-09-21 14:15:04 +04:00
libservices MDEV-12933 sort out the compression library chaos 2021-10-27 15:55:14 +02:00
man Merge 11.0 into 11.1 2023-07-26 15:13:43 +03:00
mysql-test MDEV-31273: Precompute binlog checksums 2023-10-27 19:57:43 +02:00
mysys MDEV-31273: Precompute binlog checksums 2023-10-27 19:57:43 +02:00
mysys_ssl Merge branch '10.4' into 10.5 2023-08-01 11:52:13 +02:00
plugin Merge branch '11.2' into 11.3 2023-09-30 14:12:12 +02:00
randgen/conf
scripts MDEV-12459 post-review fixes 2023-08-11 19:36:22 +02:00
sql MDEV-31273: Precompute binlog checksums 2023-10-27 19:57:43 +02:00
sql-bench Updated sql-bench to run with PostgreSQL 14.9 2023-09-09 15:14:45 +03:00
sql-common Merge branch '11.0' into 11.1 2023-08-09 08:25:14 +02:00
storage compile-time deprecation reminders 2023-09-30 14:43:12 +02:00
strings Merge branch '11.2' into 11.3 2023-09-21 14:15:04 +04:00
support-files Revert "use environment file in systemd units for _WSREP_START_POSITION" 2023-08-08 15:46:39 +01:00
tests Merge branch '11.1' into 11.2 2023-08-18 00:59:16 +02:00
tpool Merge 10.10 into 10.11 2023-04-14 13:08:28 +03:00
unittest Merge 10.9 into 10.10 2023-04-14 12:24:14 +03:00
vio Fix trivial spelling errors 2023-03-24 12:54:05 +11:00
win MDEV-32252 addendum - refactor CPackWixConfig.cmake 2023-10-04 09:30:01 +02:00
wsrep-lib@173693f2ee galera: wsrep-lib submodule update 2023-08-11 07:13:35 +02:00
zlib Merge branch 'merge-zlib' into 10.3 2023-04-20 17:06:19 +02:00
.clang-format Merge 10.4 into 10.5 2019-12-27 21:17:16 +02:00
.gitattributes Merge branch '10.5' into 10.6 2022-02-03 17:01:31 +01:00
.gitignore Revert "MDEV-30610 Update RocksDB to v8.1.1" 2023-09-30 14:12:55 +02:00
.gitlab-ci.yml Merge branch '11.1' into 11.2 2023-08-18 00:59:16 +02:00
.gitmodules Merge remote-tracking branch '10.4' into 10.5 2023-03-31 21:32:41 +02:00
appveyor.yml Merge 10.5 into 10.6 2022-07-27 17:52:37 +03:00
BUILD-CMAKE
CMakeLists.txt Merge branch '10.11' into 11.0 2023-08-09 07:53:48 +02:00
CODING_STANDARDS.md Add preprocessor whitespace to CODING_STANDARDS.md 2023-07-12 09:33:50 +10:00
config.h.cmake MDEV-31474 KDF() function 2023-09-30 14:43:12 +02:00
configure.cmake Merge 10.6 into 10.7 2022-10-13 10:05:29 +03:00
CONTRIBUTING.md Add CODING_STANDARDS.md file 2023-02-03 15:47:17 +11:00
COPYING
CREDITS CREDITS: re-instate Tencent Cloud 2023-01-25 16:44:26 +11:00
INSTALL-SOURCE
INSTALL-WIN-SOURCE
KNOWN_BUGS.txt
README.md Update README.md 2023-06-05 08:28:06 +10:00
SECURITY.md Create SECURITY.md 2023-06-05 08:28:06 +10:00
THIRDPARTY MDEV-27009: Add UCA-14.0.0 collations - License 2023-04-17 17:06:18 +10:00
VERSION 11.4 branch 2023-10-09 13:43:10 +02:00

Code status:

  • Appveyor CI status ci.appveyor.com

MariaDB: The open source relational database

MariaDB was 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 and the MariaDB Corporation. 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 Corporation, the MariaDB Foundation 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:

https://mariadb.org

https://mariadb.com/kb/en/

https://mariadb.com/kb/en/mariadb-vs-mysql-features/

https://mariadb.com/kb/en/mariadb-versus-mysql-compatibility/

https://mariadb.com/kb/en/new-and-old-releases/

Help

More help is available from the Maria Discuss mailing list https://launchpad.net/~maria-discuss, MariaDB's Zulip instance, https://mariadb.zulipchat.com/

Live QA for beginner contributors

MariaDB has a dedicated time each week when we answer new contributor questions live on Zulip. From 8:00 to 10:00 UTC on Mondays, and 10:00 to 12:00 UTC on Thursdays, anyone can ask any questions theyd like, and a live developer will be available to assist.

New contributors can ask questions any time, but we will provide immediate feedback during that interval.

Licensing


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 file. Third party license information can be found in the THIRDPARTY file.


Bug Reports

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

For reporting security vulnerabilities, see our security-policy.

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