1. 18 Jan, 2022 4 commits
    • Marko Mäkelä's avatar
      Merge 10.7 into 10.8 · e5b75ac3
      Marko Mäkelä authored
      e5b75ac3
    • Marko Mäkelä's avatar
      Merge 10.6 into 10.7 · b0998583
      Marko Mäkelä authored
      b0998583
    • Marko Mäkelä's avatar
      Merge 10.5 into 10.6 · 1abc476f
      Marko Mäkelä authored
      1abc476f
    • Marko Mäkelä's avatar
      MDEV-27499 Performance regression in log_checkpoint_margin() · e44439ab
      Marko Mäkelä authored
      In commit 4c3ad244 (MDEV-27416)
      an unnecessarily strict wait condition was introduced in the
      function buf_flush_wait(). Most callers actually only care that
      the pages have been flushed, not that a checkpoint has completed.
      
      Only in the buf_flush_sync() call for log resizing, we might care
      about the log checkpoint. But, in fact,
      srv_prepare_to_delete_redo_log_file() is explicitly disabling
      checkpoints. So, we can simply remove the unnecessary wait loop.
      
      Thanks to Krunal Bauskar for reporting this performance regression
      that we failed to repeat in our testing.
      e44439ab
  2. 17 Jan, 2022 4 commits
  3. 16 Jan, 2022 1 commit
    • Otto Kekäläinen's avatar
      Deb: Track libmariadb3 ABI explicitly to detect future symbol changes · 4775a406
      Otto Kekäläinen authored
      When this file exists, Debian builds will automatically compare the built
      ABI and symbols to the ones defined in the list. If there is a mismatch,
      developers need to update the libmariadb3.symbols file, otherwise the build
      fails.
      
      This ensures there are no accidental symbol changes. This also helps track
      what symbols changed and in what versions.
      
      Also add a README embedded in the sources to facilitate correct use of this
      new file.
      
      This change is made for branch 10.2, as it was the first server version to
      introduce an embedded libmariadb3 client library, and from this version
      the file with the same libmariadb3 specific content will be merged to
      10.3, 10.4 and 10.5.
      
      Related: MDEV-21732
      4775a406
  4. 15 Jan, 2022 3 commits
  5. 14 Jan, 2022 5 commits
    • Marko Mäkelä's avatar
      Remove FIXME comments that refer to an early MDEV-14425 plan · 8535c260
      Marko Mäkelä authored
      In MDEV-14425, an early plan was to introduce a separate log file
      for file-level records and checkpoint information. The reasoning was
      that fil_system.mutex contention would be reduced by not having to
      maintain fil_system.named_spaces. The mutex contention was actually
      fixed in MDEV-23855 by making some data fields in fil_space_t and
      fil_node_t use std::atomic.
      
      Using a single circular log file simplifies recovery and backup.
      8535c260
    • Marko Mäkelä's avatar
      Merge 10.7 into 10.8 · 347f6d01
      Marko Mäkelä authored
      347f6d01
    • Marko Mäkelä's avatar
      Merge 10.6 into 10.7 · c669e764
      Marko Mäkelä authored
      c669e764
    • Marko Mäkelä's avatar
      Merge 10.5 into 10.6 · 16b87f98
      Marko Mäkelä authored
      16b87f98
    • Marko Mäkelä's avatar
      MDEV-27500 buf_page_free() fails to drop the adaptive hash index · c104a01b
      Marko Mäkelä authored
      The function buf_page_free() that was introduced
      in commit a35b4ae8 (MDEV-15528)
      failed to remove any adaptive hash index entries for the page
      before freeing the page.
      
      This caused an assertion failure on shutdown of 10.6 server of
      in the function buf_pool_t::clear_hash_index() with the expression:
      (s >= buf_page_t::UNFIXED || s == buf_page_t::REMOVE_HASH).
      The assertion would fail for a block that is in the freed state.
      
      The failing assertion was added in
      commit aaef2e1d
      in the 10.6 branch.
      
      Thanks to Matthias Leich for finding the bug and testing the fix.
      c104a01b
  6. 13 Jan, 2022 1 commit
    • Marko Mäkelä's avatar
      MDEV-27058 fixup: Bogus assertion !block->page.is_io_fixed() · e6a06113
      Marko Mäkelä authored
      buf_page_get_gen(): After recv_sys_t::recover_low() returned,
      the page must not be read-fixed, but it may be write-fixed,
      because the io-fix state is protected by block->page.lock,
      which we are not holding yet.
      
      Also, let us copy the block descriptor state to a local variable
      for examination, so that in case an assertion would fail again,
      we will have the sampled state in the core dump. In a core dump of
      the assertion failure, we had block->page.fix() == buf_page_t::UNFIXED,
      that is, the assertion expression was holding again.
      e6a06113
  7. 12 Jan, 2022 8 commits
  8. 11 Jan, 2022 2 commits
    • Eugene Kosov's avatar
      MDEV-27022 Buffer pool is being flushed during recovery · f443cd11
      Eugene Kosov authored
      The problem was introduced by the removal of buf_pool.flush_rbt
      in commit 46b1f500 (MDEV-23399)
      
      recv_sys_t::apply(): don't write to disc and fsync() the last batch.
      Insead, sort it by oldest_modification for MariaDB server and some
      mariabackup operations.
      
      log_sort_flush_list(): a thread-safe function which sorts buf_pool::flush_list
      f443cd11
    • Sergei Golubchik's avatar
      C/C 3.3 · f8259545
      Sergei Golubchik authored
      f8259545
  9. 10 Jan, 2022 3 commits
    • Thirunarayanan Balathandayuthapani's avatar
      MDEV-27640 trx_has_lock_x() gives wrong result if the table has pending table lock · 428b057e
      Thirunarayanan Balathandayuthapani authored
      trx_has_lock_x() fails to find whether the trx has X-lock on the table
      when other transactions are waiting for an X or S lock on the table.
      428b057e
    • Marko Mäkelä's avatar
      Cleanup: Remove unused log_cmdq_key · fcbd3989
      Marko Mäkelä authored
      There was an intention to add a CommandQueue in
      mysql/mysql-server@eca5b0fc17a5bd6d4833d35a0d08c8549dd3b5ec
      but it never appeared in any release (not even MySQL 5.7.3
      where that commit appeared).
      fcbd3989
    • Rucha Deodhar's avatar
      MDEV-23836: Assertion `! is_set() || m_can_overwrite_status' in · 81e00485
      Rucha Deodhar authored
      Diagnostics_area::set_error_status (interrupted ALTER TABLE under LOCK)
      
      Analysis: KILL_QUERY is not ignored when local memory used exceeds maximum
      session memory. Hence the query proceeds, OK is sent and we end up
      reopening tables that are marked for reopen. During this, kill status is
      eventually checked and assertion failure happens during trying to send error
      message because OK has already been sent.
      Fix: Ok is already sent so statement has already executed. It is too
      late to give error. So ignore kill.
      81e00485
  10. 09 Jan, 2022 2 commits
  11. 07 Jan, 2022 1 commit
    • Hugo Wen's avatar
      MDEV-27435: Support extra initialization file for mysql_install_db · a81c75f5
      Hugo Wen authored
      The mysql_install_db script is used to initialize the data directory.
      However, if the user needs to apply some customized init commands (for
      example to change user or password) they have to start the database
      with `--skip-grant-tables` after the install script, and then restart
      the database with normal mode.
      
      To make it easier to include customization in the mysql_install_db
      script, in this commit, a new parameter `extra-file` is added in
      mysql_install_db script to support some extra customized init commands.
      
      With this option we can support applying extra file containing sql for
      mysql_install_db command line at runtime, which reduces the complexity
      of customized initialization process.
      
      This script is only used for install and is not included in the mtr
      bootstrap file.
      
      All new code of the whole pull request, including one or several files
      that are either new files or modified ones, are contributed under the
      BSD-new license. I am contributing on behalf of my employer Amazon Web
      Services, Inc.
      a81c75f5
  12. 05 Jan, 2022 6 commits