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
mariadb-DebarunBanerjee e515e80773 MDEV-34689 Redo log corruption at high load
Issue: During mtr_t:commit, if there is not enough space available in
redo log buffer, we flush the buffer. During flush, the LSN lock is
released allowing other concurrent mtr to commit. After flush we
reacquire the lock but use the old LSN obtained before check. It could
lead to redo log corruption. As the LSN moves backwards with the
possibility of data loss and unrecoverable server if the server aborts
for any reason or if server is shutdown with innodb_fast_shutdown=2.
With normal shutdown, recovery fails to map the checkpoint LSN to
correct offset.

In debug mode it hits log0log.cc:863: lsn_t log_t::write_buf()
Assertion `new_buf_free == ((lsn - first_lsn) & write_size_1)' failed.

In release mode, after normal shutdown, restart fails.
[ERROR] InnoDB: Missing FILE_CHECKPOINT(8416546) at 8416546
[ERROR] InnoDB: Log scan aborted at LSN 8416546

Backup fails reading the corrupt redo log.
[00] 2024-07-31 20:59:10 Retrying read of log at LSN=7334851
[00] FATAL ERROR: 2024-07-31 20:59:11 Was only able to copy log from
7334851 to 7334851, not 8416446; try increasing innodb_log_file_size

Unless a backup is tried or the server is shutdown or killed
immediately, the corrupt redo part is eventually truncated and there
may not be any visible issues seen in release mode.

This issue was introduced by the following commit.

commit a635c40648
    MDEV-27774 Reduce scalability bottlenecks in mtr_t::commit()

Fix: If we need to release latch and flush redo before writing mtr
logs, make sure to get the latest system LSN after reacquiring the
redo system latch.
2024-08-03 13:11:35 +05:30
.github Merge 10.6 into 10.9 2023-05-19 15:11:06 +03:00
BUILD Merge branch '10.6' into 10.11 2024-04-26 08:02:49 +02:00
client Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
cmake Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
dbug Merge 10.6 into 10.8 2023-02-10 13:43:53 +02:00
debian MDEV-33750: postfix debian-start.inc 2024-08-02 18:55:03 +10:00
Docs Merge 10.4 into 10.5 2022-09-26 13:34:38 +03:00
extra Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
include Merge 10.6 into 10.11 2024-06-11 12:50:10 +03:00
libmariadb@486ce75d64 New CC 3.3 2024-07-19 13:46:35 +02:00
libmysqld Merge branch '10.6' into 10.11 2024-05-10 20:02:18 +02:00
libservices Merge 10.6 into 10.11 2024-02-08 15:04:46 +02:00
man Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
mysql-test MDEV-33087 ALTER TABLE...ALGORITHM=COPY should build indexes more efficiently 2024-07-30 11:59:01 +05:30
mysys Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
mysys_ssl MDEV-33746 Supply missing override markings 2024-06-20 11:32:13 -04:00
plugin Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
randgen/conf
scripts Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
sql MDEV-33087 ALTER TABLE...ALGORITHM=COPY should build indexes more efficiently 2024-07-30 11:59:01 +05:30
sql-bench Updated sql-bench to run with PostgreSQL 14.9 2023-09-09 15:14:45 +03:00
sql-common Merge 10.6 into 10.11 2024-05-30 16:04:00 +03:00
storage MDEV-34689 Redo log corruption at high load 2024-08-03 13:11:35 +05:30
strings Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
support-files Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
tests Merge remote-tracking branch 'origin/10.6' into 10.11 2024-07-08 21:52:08 +04:00
tpool Merge branch '10.6' into 10.11 2024-07-04 11:52:07 +02:00
unittest Merge 10.6 into 10.11 2024-06-27 10:26:09 +03:00
vio Merge 10.6 into 10.11 2024-03-28 09:16:57 +02:00
win MDEV-33420: HASHICORP_KEY_MANAGEMENT fails on Windows with libcurl installed 2024-04-18 01:45:24 +02:00
wsrep-lib@31db847676 galera: wsrep-lib submodule update 2024-06-06 19:37:31 +02:00
zlib Merge branch 'merge-zlib' (1.3.1) into 10.4 2024-04-26 13:50:03 +02:00
.clang-format Remove duplicate key "Language" from .clang-format 2024-04-17 16:52:37 +02:00
.gitattributes Merge branch '10.5' into 10.6 2022-02-03 17:01:31 +01:00
.gitignore Updated sql-bench to run with PostgreSQL 14.9 2023-09-09 15:14:45 +03:00
.gitlab-ci.yml Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +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 2024-06-07 10:03:51 +03:00
BUILD-CMAKE
CMakeLists.txt Merge branch '10.6' into 10.11 2024-07-04 11:52:07 +02:00
config.h.cmake Merge branch '10.6' into 10.11 2024-05-10 20:02:18 +02:00
configure.cmake Merge branch '10.6' into 10.11 2024-07-22 15:14:50 +02:00
CONTRIBUTING.md Remove mention of Freenode 2021-09-22 07:15:08 +02: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 for branch choice 2024-05-29 13:49:32 +01:00
THIRDPARTY Merge branch '10.6' into 10.11 2024-02-01 18:36:14 +01:00
VERSION bump the VERSION 2024-05-15 10:54:18 -04:00

Code status:

  • Appveyor CI status ci.appveyor.com

MariaDB: The innovative open source 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/

Getting the code, building it and testing it

Refer to the following guide: https://mariadb.org/get-involved/getting-started-for-developers/get-code-build-test/ which outlines how to build the source code correctly and run the MariaDB testing framework, as well as which branch to target for your contributions.

Help

More help is available from the Maria Discuss mailing list https://lists.mariadb.org/postorius/lists/discuss.lists.mariadb.org/ and MariaDB's Zulip instance, https://mariadb.zulipchat.com/

Licensing


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: https://mariadb.org/about/security-policy/

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