An error occurred fetching the project authors.
  1. 01 Mar, 2019 2 commits
    • Marko Mäkelä's avatar
      MDEV-18775 Fix ALTER TABLE error handling for DROP INDEX · 4a1c6629
      Marko Mäkelä authored
      On an error (such as when an index cannot be dropped due to
      FOREIGN KEY constraints), the field dict_index_t::to_be_dropped
      was only being cleared in debug builds, even though the field
      is available and being used also in non-debug builds.
      
      This was a regression that was introduced by myself originally
      in MySQL 5.7.6 and later merged to MariaDB 10.2.2, in
      https://github.com/mysql/mysql-server/commit/d39898de8e0de21f64ce94cd4ea698675edfb447
      
      An error manifested itself in the MariaDB Server 10.4 non-debug build,
      involving instant ADD or DROP column. Because an earlier failed
      ALTER TABLE operation incorrectly left the dict_index_t::to_be_dropped
      flag set, the column pointers of the index fields would fail to be
      adjusted for instant ADD or DROP column (MDEV-15562). The instant
      ADD COLUMN in MariaDB Server 10.3 is unlikely to be affected by a
      similar scenario, because dict_table_t::instant_add_column() in 10.3
      is applying the transformations to all indexes, not skipping
      to-be-dropped ones.
      4a1c6629
    • Jan Lindström's avatar
      003b5074
  2. 28 Feb, 2019 3 commits
  3. 26 Feb, 2019 2 commits
    • Alexander Barkov's avatar
      MDEV-17725 Assertion `!is_set() || (m_status == DA_OK_BULK && is_bulk_op())'... · cac14b92
      Alexander Barkov authored
      MDEV-17725 Assertion `!is_set() || (m_status == DA_OK_BULK && is_bulk_op())' failed in Diagnostics_area::set_ok_status upon ALTER failing due to error from engine
      cac14b92
    • Julius Goryavsky's avatar
      MDEV-9519: Data corruption will happen on the Galera cluster size change · 2c734c98
      Julius Goryavsky authored
      If we have a 2+ node cluster which is replicating from an async master
      and the binlog_format is set to STATEMENT and multi-row inserts are executed
      on a table with an auto_increment column such that values are automatically
      generated by MySQL, then the server node generates wrong auto_increment
      values, which are different from what was generated on the async master.
      
      In the title of the MDEV-9519 it was proposed to ban start slave on a Galera
      if master binlog_format = statement and wsrep_auto_increment_control = 1,
      but the problem can be solved without such a restriction.
      
      The causes and fixes:
      
      1. We need to improve processing of changing the auto-increment values
      after changing the cluster size.
      
      2. If wsrep auto_increment_control switched on during operation of
      the node, then we should immediately update the auto_increment_increment
      and auto_increment_offset global variables, without waiting of the next
      invocation of the wsrep_view_handler_cb() callback. In the current version
      these variables retain its initial values if wsrep_auto_increment_control
      is switched on during operation of the node, which leads to inconsistent
      results on the different nodes in some scenarios.
      
      3. If wsrep auto_increment_control switched off during operation of the node,
      then we must return the original values of the auto_increment_increment and
      auto_increment_offset global variables, as the user has set. To make this
      possible, we need to add a "shadow copies" of these variables (which stores
      the latest values set by the user).
      
      https://jira.mariadb.org/browse/MDEV-9519
      2c734c98
  4. 25 Feb, 2019 1 commit
    • Julius Goryavsky's avatar
      MDEV-9519: Data corruption will happen on the Galera cluster size change · 243f829c
      Julius Goryavsky authored
      If we have a 2+ node cluster which is replicating from an async master
      and the binlog_format is set to STATEMENT and multi-row inserts are executed
      on a table with an auto_increment column such that values are automatically
      generated by MySQL, then the server node generates wrong auto_increment
      values, which are different from what was generated on the async master.
      
      In the title of the MDEV-9519 it was proposed to ban start slave on a Galera
      if master binlog_format = statement and wsrep_auto_increment_control = 1,
      but the problem can be solved without such a restriction.
      
      The causes and fixes:
      
      1. We need to improve processing of changing the auto-increment values
      after changing the cluster size.
      
      2. If wsrep auto_increment_control switched on during operation of
      the node, then we should immediately update the auto_increment_increment
      and auto_increment_offset global variables, without waiting of the next
      invocation of the wsrep_view_handler_cb() callback. In the current version
      these variables retain its initial values if wsrep_auto_increment_control
      is switched on during operation of the node, which leads to inconsistent
      results on the different nodes in some scenarios.
      
      3. If wsrep auto_increment_control switched off during operation of the node,
      then we must return the original values of the auto_increment_increment and
      auto_increment_offset global variables, as the user has set. To make this
      possible, we need to add a "shadow copies" of these variables (which stores
      the latest values set by the user).
      
      https://jira.mariadb.org/browse/MDEV-9519
      243f829c
  5. 23 Feb, 2019 4 commits
  6. 22 Feb, 2019 1 commit
    • Marko Mäkelä's avatar
      MDEV-10813: Update buf_page_t::buf_fix_count outside mutex · 2c8d9a4e
      Marko Mäkelä authored
      Since MySQL 5.6.16 (and MariaDB Server 10.0.11), changes of
      buf_page_t::buf_fix_count are atomic memory operations if
      PAGE_ATOMIC_REF_COUNT is defined. Since MySQL 5.7
      (and MariaDB Server 10.2.2), the field is always updated
      by atomic memory operations.
      
      In a few occurrences, updates of the counter were unnecessarily
      surrounded by an acquisition and release of the block mutex
      (buf_block_t::mutex or buf_pool_t::zip_mutex). Remove these
      unnecessary mutex operations.
      2c8d9a4e
  7. 21 Feb, 2019 2 commits
  8. 20 Feb, 2019 5 commits
  9. 19 Feb, 2019 9 commits
  10. 18 Feb, 2019 3 commits
  11. 14 Feb, 2019 2 commits
  12. 13 Feb, 2019 3 commits
  13. 12 Feb, 2019 2 commits
    • Marko Mäkelä's avatar
      Merge 10.1 into 10.2 · 8a9cdc5f
      Marko Mäkelä authored
      8a9cdc5f
    • Julius Goryavsky's avatar
      MDEV-18426: Most of the mtr tests in the galera_3nodes suite fail · 5b827511
      Julius Goryavsky authored
      Most of the mtr tests in the galera_3nodes suite fail
      for a variety of reasons with a variety of errors.
      
      This patch fixes several substantial flaws
      in the galera_3nodes suite tests and in the mtr framework
      service files, adapting the tests from galera_3nodes
      for the current version of MariaDB.
      
      This patch also synchronizes some galera_3nodes-related
      files with the latest changes made for MDEV-17835 (v2 patch)
      and for MDEV-18379 in other branches (10.2 and 10.3).
      
      Closes #1161
      5b827511
  14. 11 Feb, 2019 1 commit