1. 22 Jun, 2017 5 commits
    • Sergei Golubchik's avatar
      MDEV-13097 Online alter of a partitioned MyISAM table with auto_increment · 3f240bff
      Sergei Golubchik authored
      MyISAM only allows online alter if autoincrement didn't change.
      MyISAM detects that by comparing new autoinc value from create_info,
      with the old one, stored in MYI. But in partitioned tables,
      create_info->auto_increment_value is for the whole table, max of
      autoinc values of individual MYI partitions. So *some* MYI partitions
      will inevitably think that alter table changes auto_increment value
      and will deny online alter.
      
      Fix: only compare autoinc values, if the user has used AUTO_INCREMENT
      in the ALTER TABLE statement.
      3f240bff
    • Sergei Golubchik's avatar
      MDEV-13012 Assertion `share->error' failed in discover_handlerton upon... · b6ce68f4
      Sergei Golubchik authored
      MDEV-13012 Assertion `share->error' failed in discover_handlerton upon executing statement with max_session_mem_used = 8192
      
      and
      MDEV-13011 Server crashes in THD::handle_condition or Assertion `! is_set() || m_can_overwrite_status' fails upon attempt to connect with max_session_mem_used = 8192
      
      errors when a connection is killed in the
      * TABLE_SHARE::init_from_sql_statement_string()
      * THD::init()
      
      also, safety-wise, don't check max_mem_used on free() and when some error
      was already issued.
      b6ce68f4
    • Sergei Golubchik's avatar
    • Sergei Golubchik's avatar
      disable getopt prefix matching in mtr bootstrap · d4007f2e
      Sergei Golubchik authored
      it was disabled in mtr tests in 4280b25e
      d4007f2e
    • Sachin Setiya's avatar
      MDEV-12398 All cluster nodes stop due to a foreign key constraint failure · e333d829
      Sachin Setiya authored
      Comment from Codership:-
      To fix the problem, we changed the certification logic in galera to treat insert
      on child table row as exclusive to prevent any operation on referenced
      parent table row. At the same time, update and delete on
       child table row were demoted to "shared", which makes it possible to
      update/delete referenced parent table row, but only in a later transaction.
       This change allows somewhat more concurrency for foreign key constrained
       transactions, but is still safe for correct certification end result.
      e333d829
  2. 19 Jun, 2017 7 commits
  3. 16 Jun, 2017 1 commit
  4. 15 Jun, 2017 2 commits
    • Marko Mäkelä's avatar
      Remove some fields from dict_table_t · 58f87a41
      Marko Mäkelä authored
      dict_table_t::thd: Remove. This was only used by btr_root_block_get()
      for reporting decryption failures, and it was only assigned by
      ha_innobase::open(), and never cleared. This could mean that if a
      connection is closed, the pointer would become stale, and the server
      could crash while trying to report the error. It could also mean
      that an error is being reported to the wrong client. It is better
      to use current_thd in this case, even though it could mean that if
      the code is invoked from an InnoDB background operation, there would
      be no connection to which to send the error message.
      
      Remove dict_table_t::crypt_data and dict_table_t::page_0_read.
      These fields were never read.
      
      fil_open_single_table_tablespace(): Remove the parameter "table".
      58f87a41
    • Marko Mäkelä's avatar
      88b96181
  5. 13 Jun, 2017 3 commits
  6. 12 Jun, 2017 7 commits
  7. 09 Jun, 2017 3 commits
    • Marko Mäkelä's avatar
      MDEV-13039 innodb_fast_shutdown=0 may fail to purge all undo log · 417434f1
      Marko Mäkelä authored
      When a slow shutdown is performed soon after spawning some work for
      background threads that can create or commit transactions, it is possible
      that new transactions are started or committed after the purge has finished.
      This is violating the specification of innodb_fast_shutdown=0, namely that
      the purge must be completed. (None of the history of the recent transactions
      would be purged.)
      
      Also, it is possible that the purge threads would exit in slow shutdown
      while there exist active transactions, such as recovered incomplete
      transactions that are being rolled back. Thus, the slow shutdown could
      fail to purge some undo log that becomes purgeable after the transaction
      commit or rollback.
      
      srv_undo_sources: A flag that indicates if undo log can be generated
      or the persistent, whether by background threads or by user SQL.
      Even when this flag is clear, active transactions that already exist
      in the system may be committed or rolled back.
      
      innodb_shutdown(): Renamed from innobase_shutdown_for_mysql().
      Do not return an error code; the operation never fails.
      Clear the srv_undo_sources flag, and also ensure that the background
      DROP TABLE queue is empty.
      
      srv_purge_should_exit(): Do not allow the purge to exit if
      srv_undo_sources are active or the background DROP TABLE queue is not
      empty, or in slow shutdown, if any active transactions exist
      (and are being rolled back).
      
      srv_purge_coordinator_thread(): Remove some previous workarounds
      for this bug.
      
      innobase_start_or_create_for_mysql(): Set buf_page_cleaner_is_active
      and srv_dict_stats_thread_active directly. Set srv_undo_sources before
      starting the purge subsystem, to prevent immediate shutdown of the purge.
      Create dict_stats_thread and fts_optimize_thread immediately
      after setting srv_undo_sources, so that shutdown can use this flag to
      determine if these subsystems were started.
      
      dict_stats_shutdown(): Shut down dict_stats_thread. Backported from 10.2.
      
      srv_shutdown_table_bg_threads(): Remove (unused).
      417434f1
    • Marko Mäkelä's avatar
      Correct a merge error of MDEV-11626 · a9117c90
      Marko Mäkelä authored
      a9117c90
    • Jan Lindström's avatar
      MDEV-12610: MariaDB start is slow · 58c56dd7
      Jan Lindström authored
      Problem appears to be that the function fsp_flags_try_adjust()
      is being unconditionally invoked on every .ibd file on startup.
      Based on performance investigation also the top function
      fsp_header_get_crypt_offset() needs to addressed.
      
      Ported implementation of fsp_header_get_encryption_offset()
      function from 10.2 to fsp_header_get_crypt_offset().
      
      Introduced a new function fil_crypt_read_crypt_data()
      to read page 0 if it is not yet read.
      
      fil_crypt_find_space_to_rotate(): Now that page 0 for every .ibd
      file is not read on startup we need to check has page 0 read
      from space that we investigate for key rotation, if it is not read
      we read it.
      
      fil_space_crypt_get_status(): Now that page 0 for every .ibd
      file is not read on startup here also we need to read page 0
      if it is not yet read it. This is needed
      as tests use IS query to wait until background encryption
      or decryption has finished and this function is used to
      produce results.
      
      fil_crypt_thread(): Add is_stopping condition for tablespace
      so that we do not rotate pages if usage of tablespace should
      be stopped. This was needed for failure seen on regression
      testing.
      
      fil_space_create: Remove page_0_crypt_read and extra
      unnecessary info output.
      
      fil_open_single_table_tablespace(): We call fsp_flags_try_adjust
      only when when no errors has happened and server was not started
      on read only mode and tablespace validation was requested or
      flags contain other table options except low order bits to
      FSP_FLAGS_POS_PAGE_SSIZE position.
      
      fil_space_t::page_0_crypt_read removed.
      
      Added test case innodb-first-page-read to test startup when
      encryption is on and when encryption is off to check that not
      for all tables page 0 is read on startup.
      58c56dd7
  8. 08 Jun, 2017 5 commits
    • Marko Mäkelä's avatar
      Cleanup of MDEV-12600: crash during install_db with innodb_page_size=32K and ibdata1=3M · fbeb9489
      Marko Mäkelä authored
      The doublewrite buffer pages must fit in the first InnoDB system
      tablespace data file. The checks that were added in the initial patch
      (commit 112b21da)
      were at too high level and did not cover all cases.
      
      innodb.log_data_file_size: Test all innodb_page_size combinations.
      
      fsp_header_init(): Never return an error. Move the change buffer creation
      to the only caller that needs to do it.
      
      btr_create(): Clean up the logic. Remove the error log messages.
      
      buf_dblwr_create(): Try to return an error on non-fatal failure.
      Check that the first data file is big enough for creating the
      doublewrite buffers.
      
      buf_dblwr_process(): Check if the doublewrite buffer is available.
      Display the message only if it is available.
      
      recv_recovery_from_checkpoint_start_func(): Remove a redundant message
      about FIL_PAGE_FILE_FLUSH_LSN mismatch when crash recovery has already
      been initiated.
      
      fil_report_invalid_page_access(): Simplify the message.
      
      fseg_create_general(): Do not emit messages to the error log.
      
      innobase_init(): Revert the changes.
      
      trx_rseg_create(): Refactor (no functional change).
      fbeb9489
    • Jan Lindström's avatar
      d03abc71
    • Marko Mäkelä's avatar
      Revert part of MDEV-12113 · 68890fe7
      Marko Mäkelä authored
      commit 1af8bf39 added unnecessary
      calls to fil_write_flushed_lsn() during redo log resizing at
      InnoDB server startup.
      
      Because fil_write_flushed_lsn() is neither redo-logged nor doublewrite
      buffered, the call is risky and should be avoided, because if the
      server killed during the write call, the whole InnoDB instance can
      become inaccessible (corrupted page 0 in the system tablespace).
      
      In the best case, this call might prevent a diagnostic message from
      being emitted to the error log on the next startup.
      68890fe7
    • Jan Lindström's avatar
      Merge pull request #404 from grooverdan/10.1-MDEV-13032-galera_new_cluster · 18f62d94
      Jan Lindström authored
      MDEV-13032: fix galera_new_cluster to be POSIX
      18f62d94
    • Daniel Black's avatar
      d8515829
  9. 06 Jun, 2017 3 commits
    • Marko Mäkelä's avatar
      Correct a merge error · 6439238c
      Marko Mäkelä authored
      6439238c
    • Marko Mäkelä's avatar
      Merge 10.0 into 10.1 · 30df297c
      Marko Mäkelä authored
      Rewrite the test encryption.innodb-checksum-algorithm not to
      require any restarts or re-bootstrapping, and to cover all
      innodb_page_size combinations.
      
      Test innodb.101_compatibility with all innodb_page_size combinations.
      30df297c
    • Marko Mäkelä's avatar
      Follow-up to MDEV-12042 (test innodb_page_size variants) · d8d39721
      Marko Mäkelä authored
      innodb_page_size_small: A new set of combinations, for
      innodb_page_size up to 16k. In MariaDB 10.0, this does not
      make a difference, but in 10.1 and later, innodb_page_size
      would cover 32k and 64k, for which ROW_FORMAT=COMPRESSED
      is not available.
      
      Enable these combinations in a few InnoDB tests.
      d8d39721
  10. 05 Jun, 2017 2 commits
  11. 01 Jun, 2017 2 commits
    • Elena Stepanova's avatar
    • Jan Lindström's avatar
      MDEV-12600: crash during install_db with innodb_page_size=32K and ibdata1=3M; · 112b21da
      Jan Lindström authored
      Problem was that all doublewrite buffer pages must fit to first
      system datafile.
      
      Ported commit 27a34df7882b1f8ed283f22bf83e8bfc523cbfde
      Author: Shaohua Wang <shaohua.wang@oracle.com>
      Date:   Wed Aug 12 15:55:19 2015 +0800
      
          BUG#21551464 - SEGFAULT WHILE INITIALIZING DATABASE WHEN
          INNODB_DATA_FILE SIZE IS SMALL
      
      To 10.1 (with extended error printout).
      
      btr_create(): If ibuf header page allocation fails report error and
      return FIL_NULL. Similarly if root page allocation fails return a error.
      
      dict_build_table_def_step: If fsp_header_init fails return
      error code.
      
      fsp_header_init: returns true if header initialization succeeds
      and false if not.
      
      fseg_create_general: report error if segment or page allocation fails.
      
      innobase_init: If first datafile is smaller than 3M and could not
      contain all doublewrite buffer pages report error and fail to
      initialize InnoDB plugin.
      
      row_truncate_table_for_mysql: report error if fsp header init
      fails.
      
      srv_init_abort: New function to report database initialization errors.
      
      srv_undo_tablespaces_init, innobase_start_or_create_for_mysql: If
      database initialization fails report error and abort.
      
      trx_rseg_create: If segment header creation fails return.
      112b21da