1. 17 Jan, 2016 4 commits
  2. 15 Jan, 2016 3 commits
    • Kristian Nielsen's avatar
      After-merge fix. · 38bcb446
      Kristian Nielsen authored
      38bcb446
    • Kristian Nielsen's avatar
      Merge branch 'tmp' into tmp-10.1 · 2f88b14a
      Kristian Nielsen authored
      Conflicts:
      	sql/slave.cc
      2f88b14a
    • Kristian Nielsen's avatar
      Fix error handling for GTID and domain-based parallel replication · 06b2e327
      Kristian Nielsen authored
      This occurs when replication stops with an error, domain-based parallel
      replication is used, and the GTID position contains more than one domain.
      Furthermore, it relates to the case where the SQL thread is restarted
      without first stopping the IO thread.
      
      In this case, the file/offset relay-log position does not correctly
      represent the slave's multi-dimensional position, because other domains may
      be far ahead of, or behind, the domain with the failing event. So the code
      reverts the relay log position back to the start of a relay log file that is
      known to be before all active domains.
      
      There was a bug that when the SQL thread was restarted, the
      rli->relay_log_state was incorrectly initialised from @@gtid_slave_pos. This
      position will likely be too far ahead, due to reverting the relay log
      position. Thus, if the replication fails again after the SQL thread restart,
      the rli->restart_gtid_pos might be updated incorrectly. This in turn would
      cause a second SQL thread restart to replicate from the wrong position, if
      the IO thread was still left running.
      
      The fix is to initialise rli->relay_log_state from @@gtid_slave_pos only
      when we actually purge and re-fetch relay logs from the master, not at every
      SQL thread start.
      
      A related problem is the use of sql_slave_skip_counter to resolve
      replication failures in this kind of scenario. Since the slave position is
      multi-dimensional, sql_slave_skip_counter can not work properly - it is
      indeterminate exactly which event is to be skipped, and is unlikely to work
      as expected for the user. So make this an error in the case where
      domain-based parallel replication is used with multiple domains, suggesting
      instead the user to set @@gtid_slave_pos to reliably skip the desired event.
      06b2e327
  3. 14 Jan, 2016 1 commit
  4. 05 Jan, 2016 1 commit
  5. 30 Dec, 2015 3 commits
  6. 29 Dec, 2015 9 commits
  7. 27 Dec, 2015 1 commit
    • Sergey Vojtovich's avatar
      MDEV-9128 - Compiling on IBM System Z fails · 30b2447f
      Sergey Vojtovich authored
      Provided IBM System Z have outdated compiler version, which supports gcc sync
      builtins but not gcc atomic builtins. It also has weak memory model.
      
      InnoDB attempted to verify if __sync_lock_test_and_set() is available by
      checking IB_STRONG_MEMORY_MODEL. This macro has nothing to do with availability
      of __sync_lock_test_and_set(), the right one is HAVE_ATOMIC_BUILTINS.
      30b2447f
  8. 24 Dec, 2015 1 commit
  9. 23 Dec, 2015 6 commits
  10. 22 Dec, 2015 9 commits
  11. 21 Dec, 2015 2 commits
    • Sergei Golubchik's avatar
      MDEV-8605 MariaDB not use DEFAULT value even when inserted NULL for NOT NULLABLE column · 0686c34d
      Sergei Golubchik authored
      NOT NULL constraint must be checked *after* the BEFORE triggers.
      That is for INSERT and UPDATE statements even NOT NULL fields
      must be able to store a NULL temporarily at least while
      BEFORE INSERT/UPDATE triggers are running.
      0686c34d
    • Sergei Golubchik's avatar
      cleanup · ad5db17e
      Sergei Golubchik authored
      * move common code to a new set_bad_null_error() function
      * move repeated comparison out of the loop
      * remove unused code
        * unused method Table_triggers_list::set_table
        * redundant condition (if (table) after table was dereferenced)
      * add an assert
      ad5db17e