1. 01 Dec, 2020 1 commit
    • Vlad Lesin's avatar
      MDEV-22929 MariaBackup option to report and/or continue when corruption is encountered · d5c11fb0
      Vlad Lesin authored
      The new option --log-innodb-page-corruption is introduced.
      
      When this option is set, backup is not interrupted if innodb corrupted
      page is detected. Instead it logs all found corrupted pages in
      innodb_corrupted_pages file in backup directory and finishes with error.
      
      For incremental backup corrupted pages are also copied to .delta file,
      because we can't do LSN check for such pages during backup,
      innodb_corrupted_pages will also be created in incremental backup
      directory.
      
      During --prepare, corrupted pages list is read from the file just after
      redo log is applied, and each page from the list is checked if it is allocated
      in it's tablespace or not. If it is not allocated, then it is zeroed out,
      flushed to the tablespace and removed from the list. If all pages are removed
      from the list, then --prepare is finished successfully and
      innodb_corrupted_pages file is removed from backup directory. Otherwise
      --prepare is finished with error message and innodb_corrupted_pages contains
      the list of the pages, which are detected as corrupted during backup, and are
      allocated in their tablespaces, what means backup directory contains corrupted
      innodb pages, and backup can not be considered as consistent.
      
      For incremental --prepare corrupted pages from .delta files are applied
      to the base backup, innodb_corrupted_pages is read from both base in
      incremental directories, and the same action is proceded for corrupted
      pages list as for full --prepare. innodb_corrupted_pages file is
      modified or removed only in base directory.
      
      If DDL happens during backup, it is also processed at the end of backup
      to have correct tablespace names in innodb_corrupted_pages.
      d5c11fb0
  2. 23 Nov, 2020 1 commit
    • Sujatha's avatar
      MDEV-23846: O_TMPFILE error in mysqlbinlog stream output breaks restore · 7effcb8e
      Sujatha authored
      Problem:
      ========
      When O_TMPFILE is not supported mysqlbinlog outputs the error to standard
      stream as a warning which breaks PITR:
      
      ERROR 1064 (42000) at line 382: You have an error in your SQL syntax; check
      the manual that corresponds to your MariaDB server version for the right
      syntax to use near 'mysqlbinlog: O_TMPFILE is not supported on /tmp (disabling
          future attempts)
      
      Analysis:
      =========
      'mysqlbinlog' utility is used to perform point-in-time-recovery based on binary
      log. It converts the events in the binary log files, from binary format to text
      so that they can be viewed or applied. This output can be saved to a file and
      it can be sourced back to mysql client. The mysqlbinlog utility stores the
      text output into IO_CACHE and when it is full the data is written to a temp
      file.  The temporary file creation is attempted using 'O_TMPFILE' flag. If the
      underlying filesystem doesn't support this operation, a note is printed on to
      standard error and file creation is done without O_TMPFILE' flag. If standard
      error is redirected to standard output the note gets written to the sql file
      as shown below.
      
      /bld/client/mysqlbinlog: O_TMPFILE is not supported on /tmp (disabling future
          attempts)
      table id 32
      
      When the sql file is used for PITR, it leads to a syntax error as it is not a
      valid sql command.
      
      Fix:
      ====
      Make 'my_message_stderr' to ignore messages which are flagged as ME_NOTE and
      ME_ERROR_LOG_ONLY. ME_ERROR_LOG_ONLY flag is applicable to server. In order to
      print an informational note to stderr stream, ME_NOTE flag without
      ME_ERROR_LOG_ONLY flag should be specified. 'my_message_stderr' should print
      messages flagged with ME_WARNING or ME_FATAL to stderr stream.
      7effcb8e
  3. 19 Nov, 2020 5 commits
  4. 17 Nov, 2020 3 commits
  5. 16 Nov, 2020 2 commits
  6. 14 Nov, 2020 3 commits
  7. 13 Nov, 2020 6 commits
    • Marko Mäkelä's avatar
      MDEV-24188: Merge 10.3 into 10.4 · 749ecedf
      Marko Mäkelä authored
      749ecedf
    • Marko Mäkelä's avatar
      MDEV-23619: Merge 10.3 into 10.4 · b63dc3f3
      Marko Mäkelä authored
      b63dc3f3
    • Marko Mäkelä's avatar
      MDEV-24188: Merge 10.2 into 10.3 · f9f2f374
      Marko Mäkelä authored
      f9f2f374
    • Marko Mäkelä's avatar
      MDEV-23619: Merge 10.2 into 10.3 · 6fed6de9
      Marko Mäkelä authored
      6fed6de9
    • Marko Mäkelä's avatar
      MDEV-24188 Hang in buf_page_create() after reusing a previously freed page · bb328a2a
      Marko Mäkelä authored
      The fix of MDEV-23456 (commit b1009ae5)
      introduced a livelock between page flushing and a thread that is
      executing buf_page_create().
      
      buf_page_create(): If the current mini-transaction is holding
      an exclusive latch on the page, do not attempt to acquire another
      one, and do not care about any I/O fix.
      
      mtr_t::have_x_latch(): Replaces mtr_t::get_fix_count().
      
      dyn_buf_t::for_each_block(const Functor&) const: A new variant.
      
      rw_lock_own(): Add a const qualifier.
      
      Reviewed by: Thirunarayanan Balathandayuthapani
      bb328a2a
    • Igor Babaev's avatar
      MDEV-23619 MariaDB crash on WITH RECURSIVE UNION ALL (CTE) query · 190e8a4c
      Igor Babaev authored
      Due to a premature cleanup of the unit that specified a recursive CTE
      used in the second operand of union the server fell into an infinite
      loop in the reported test case. In other cases this premature cleanup
      could cause other problems.
      The bug is the result of a not quite correct fix for MDEV-17024. The
      unit that specifies a recursive CTE has to be cleaned only after the
      cleanup of the last external reference to this CTE. It means that
      cleanups of the unit triggered not by the cleanup of a external
      reference to the CTE must be blocked.
      Usage of local table chains in selects to get external references to
      recursive CTEs was not correct either because of possible merges of
      some selects.
      
      Also fixed a minor bug in st_select_lex::set_explain_type() that caused
      typing 'RECURSIVE UNION' instead of 'UNION' in EXPLAIN output for external
      references to a recursive CTE.
      190e8a4c
  8. 12 Nov, 2020 5 commits
  9. 11 Nov, 2020 12 commits
    • Marko Mäkelä's avatar
      Merge mariadb-10.2.36 into 10.2 · dd33a70d
      Marko Mäkelä authored
      dd33a70d
    • Marko Mäkelä's avatar
      Merge mariadb-10.3.27 into 10.3 · 340feb01
      Marko Mäkelä authored
      340feb01
    • sjaakola's avatar
      MDEV-24119 MDL BF-BF Conflict caused by TRUNCATE TABLE · 2fbcddbe
      sjaakola authored
      A follow-up fix, for original fix for MDEV-21577, which did not handle well
      temporary tables.
      
      OPTIMIZE and REPAIR TABLE statements can take a list of tables as argument,
      and some of the tables may be temporary. Proper handling of temporary tables
      is to skip them and continue working on the real tables. The bad version, skipped all tables,
      if a single temporary table was in the argument list. And this resulted so that FK parent
      tables were not scnanned for the remaining real tables. Some mtr tests, using OPTIMIZE or REPAIR
      for temporary tables caused regressions bacause of this, e.g. galera.galera_optimize_analyze_multi
      
      The fix in this PR opens temporary and real tables first, and in the table handling loop skips
      temporary tables, FK parent scanning is done only for real tables.
      
      The test has new scenario for OPTIMIZE and REPAIR issued for two tables of which one is temporary table.
      Reviewed-by: default avatarJan Lindström <jan.lindstrom@mariadb.com>
      2fbcddbe
    • sjaakola's avatar
      MDEV-24119 MDL BF-BF Conflict caused by TRUNCATE TABLE · ad432ef4
      sjaakola authored
      This PR fixes same issue as MDEV-21577 for TRUNCATE TABLE.
      MDEV-21577 fixed TOI replication for OPTIMIZE, REPAIR and ALTER TABLE
      operating on FK child table. It was later found out that also TRUNCATE
      has similar problem and needs a fix.
      
      The actual fix is to do FK parent table lookup before TRUNCATE TOI
      isolation and append found FK parent table names in certification key
      list for the write set.
      
      PR contains also new test scenario in galera_ddl_fk_conflict test where
      FK child has two FK parent tables and there are two DML transactions operating
      on both parent tables.
      
      For development convenience, new TO isolation macro was added:
      WSREP_TO_ISOLATION_BEGIN_IF and WSREP_TO_ISOLATION_BEGIN_ALTER macro was changed
      to skip the goto statement.
      Reviewed-by: default avatarJan Lindström <jan.lindstrom@mariadb.com>
      ad432ef4
    • Marko Mäkelä's avatar
      Merge mariadb-10.4.17 into 10.4 · 99a97747
      Marko Mäkelä authored
      99a97747
    • Daniel Bartholomew's avatar
      bump the VERSION · 940db6ab
      Daniel Bartholomew authored
      940db6ab
    • Daniel Bartholomew's avatar
      bump the VERSION · bafbfb55
      Daniel Bartholomew authored
      bafbfb55
    • Daniel Bartholomew's avatar
      bump the VERSION · 15550ed3
      Daniel Bartholomew authored
      15550ed3
    • Marko Mäkelä's avatar
      Cleanup: Remove dict_space_is_empty(), dict_space_get_id() · d6ee2858
      Marko Mäkelä authored
      As noted in commit 0b66d3f7,
      MariaDB does not support CREATE TABLESPACE for InnoDB.
      Hence, some code that was added in
      commit fec844ac
      and originally in
      mysql/mysql-server@c71dd213bd434c0579e454ab8880e6d3756b0fb0
      is unused in MariaDB and should be removed.
      d6ee2858
    • Marko Mäkelä's avatar
      MDEV-24156 trx_undo_left() fails to prevent overflow · 7b7e5922
      Marko Mäkelä authored
      trx_undo_left(): Return 0 in case of an overflow, instead of
      returning a negative number interpreted as a large positive number.
      Also, add debug assertions to check that the pointer is within
      the page area. This should allow us to catch bugs like
      MDEV-24096 easier in the future.
      7b7e5922
    • Marko Mäkelä's avatar
      MDEV-24182 ibuf_merge_or_delete_for_page() contains dead code · bd528b0c
      Marko Mäkelä authored
      The function ibuf_merge_or_delete_for_page() was always being
      invoked with update_ibuf_bitmap=true ever since
      commit cd623508
      fixed up something after MDEV-9566.
      
      Furthermore, the parameter page_size is never being passed as a
      null pointer, and therefore it should better be a reference to
      a constant object.
      bd528b0c
    • Daniele Sciascia's avatar
      Update wsrep-lib · 83f3d12f
      Daniele Sciascia authored
      Reviewed-by: default avatarJan Lindström <jan.lindstrom@mariadb.com>
      83f3d12f
  10. 10 Nov, 2020 2 commits
    • Anel Husakovic's avatar
      MDEV-24130: Cannot launch mariadbd via mysqld_safe · 3bf726f5
      Anel Husakovic authored
      - Patch 95bb3cb8 used `my_which` function in `10.2`
      - Based on patch `355ee687` from 10.3+ `command -v` is used instead of
      `my_which` so we are changing in this patch also
      - `ldconfig` is usually found in `/sbin` so make sure it is added in
      `$PATH` variable
      3bf726f5
    • Anel Husakovic's avatar
      MDEV-23769: MTR can abort before it prints the test result summary · cd927dd3
      Anel Husakovic authored
      - Patch is solving generating report on warning
              To repeat the error run single worker:
              ```
              ./mtr --mysqld=--lock-wait-timeout=-xx 1st 1st --force --parallel 1
              ```
              or `N` workers with `N+1` tests with failures and `force`
              ```
              ./mtr --mysqld=--lock-wait-timeout=-xx 1st 1st grant5 --force --parallel 2
              ```
      - Patch is doing cosmetic fix of `current_test` log file which holds the old log value of test `CURRENT TEST:..` in `mark_log()` in case of `unknown option` and as such
        the logic which is using it's content doesn't output valid log content and doesn't generate valid `$test->{'comment'}` message.asdf
      
      - Closing the socket/handler after the removing the handler from IO for
      consistency
      
      Reviewed by: serg@mariadb.com
      cd927dd3