1. 29 Dec, 2017 2 commits
    • Monty's avatar
      Made IO_CACHE safe for reading big blocks (> 2G) · afbb72b3
      Monty authored
      The reason for adding this was that while testing mysqlbinlog on
      a replication event with 3G event output, Linux failed reading
      the whole file in memory with one read (only got 2G on first read
      even if file had just been written).
      
      - Don't reset info->error on write error in IO_CACHE.
      - In case of write_error in IO_CACHE , always return -1
      - Fixed wrong result from my_read when using MY_FULL_IO. Also don't give
        an error in case of retry.
      afbb72b3
    • Monty's avatar
      mysqlbinlog now prints "# Number of rows" and stops on errors · e6418413
      Monty authored
      Main problem was that no log-event print function checked for disk
      full error on the IO_CACHE.
      All changes in this patch only affects mysqlbinlog, not the server!
      
      - Changed all log-event print functions to return 1 on error
      - Fixed memory usage when not using --flashback.
      - Added printing of number of rows in row events. Can be disabled with
        --print-row-count=0
      - Print annotated rows when using mysqlbinlog --short-form
      - Fixed that mysqlbinlog --debug works
      - Fixed create_drop_binlog.test test failure
      - Reorganized fields in PRINT_EVENT_INFO to be according to size to
        optimize storage
      - Don't change print_row_event_position or print_row_counts if set by user
      - Remove some testing of argument to my_free is 0
      - base64-output=never is now supported and works in all context
      - Updated help information for --base64-output and --short-form
      - print_row_count is now on by default. Reset automatically if --short-form
        is used
      - Removed obsolote warning for mysql 5.6.0
      - More DBUG_PRINT for mysqltest.cc
      - my_b_write_byte() now checks for flush failures. This fixed a memory
        overrun on disk full
      - my_b_printf() now returns 1 on failure, 0 on ok.  This simplifies code
        and no old code was using the old return value of my_b_printf().
      - my_b_Write_backtick_quote() now returns 1 on failure and 0 on ok
      - Fixed some error conditions in log printing that was not previously
        handled.
      - Slave_rows_error_report() can now handle longlong positions
      - Write_on_release_cache() rewritten so that we can detect errors
        on flush. Not depending on automatic release anymore.
      - Changed types for Pos and End_log_pos to 64 bit in SHOW BINLOG EVENTS
      - Fixed that copy_event_cache_to_string_and_reinit() works with strings
        longer than 4G (Changed to use LEX_STRING instead of String)
      - Restricted binlog_rows_event_max_size to UINT32_MAX-1 as String's are
        anyway restricted to UINT32_MAX
      - Fixed bug in rpl_binlog_state::write_to_iocache() which hide write
        failures (duplicate variable name)
      - Fixed bug in String::append if original string was not allocated
      - Stop mysqlbinlog output at once if there is an error.
      - Before printing error message, flush result file. This ensures that
        the error message is printed last. (Easier to find)
      e6418413
  2. 21 Dec, 2017 1 commit
  3. 20 Dec, 2017 3 commits
    • Marko Mäkelä's avatar
      69e88de0
    • Marko Mäkelä's avatar
      MDEV-14585 Automatically remove #sql- tables in InnoDB dictionary during recovery · b4165985
      Marko Mäkelä authored
      Now that MDEV-14717 made RENAME TABLE crash-safe within InnoDB,
      it should be safe to drop the #sql- tables within InnoDB during
      crash recovery. These tables can be one of two things:
      
      (1) #sql-ib related to deferred DROP TABLE (follow-up to MDEV-13407)
      or to table-rebuilding ALTER TABLE...ALGORITHM=INPLACE
      (since MDEV-14378, only related to the intermediate copy of a table),
      
      (2) #sql- related to the intermediate copy of a table during
      ALTER TABLE...ALGORITHM=COPY
      
      We will not drop tables whose name starts with #sql2, because
      the server can be killed during an ALGORITHM=COPY operation at
      a point where the original table was renamed to #sql2 but the
      finished intermediate copy was not yet renamed from #sql-
      to the original table name.
      b4165985
    • Marko Mäkelä's avatar
      MDEV-14717 RENAME TABLE in InnoDB is not crash-safe · 0bc36758
      Marko Mäkelä authored
      InnoDB in MariaDB 10.2 appears to only write MLOG_FILE_RENAME2
      redo log records during table-rebuilding ALGORITHM=INPLACE operations.
      We must write the records for any .ibd file renames, so that the
      operations are crash-safe.
      
      If InnoDB is killed during a RENAME TABLE operation, it can happen that
      the transaction for updating the data dictionary will be rolled back.
      But, nothing will roll back the renaming of the .ibd file
      (the MLOG_FILE_RENAME2 only guarantees roll-forward), or for that matter,
      the renaming of the dict_table_t::name in the dict_sys cache. We introduce
      the undo log record TRX_UNDO_RENAME_TABLE to fix this.
      
      fil_space_for_table_exists_in_mem(): Remove the parameters
      adjust_space, table_id and some code that was trying to work around
      these deficiencies.
      
      fil_name_write_rename(): Write a MLOG_FILE_RENAME2 record.
      
      dict_table_rename_in_cache(): Invoke fil_name_write_rename().
      
      trx_undo_rec_copy(): Set the first 2 bytes to the length of the
      copied undo log record.
      
      trx_undo_page_report_rename(), trx_undo_report_rename():
      Write a TRX_UNDO_RENAME_TABLE record with the old table name.
      
      row_rename_table_for_mysql(): Invoke trx_undo_report_rename()
      before modifying any data dictionary tables.
      
      row_undo_ins_parse_undo_rec(): Roll back TRX_UNDO_RENAME_TABLE
      by invoking dict_table_rename_in_cache(), which will take care
      of both renaming the table and the file.
      0bc36758
  4. 19 Dec, 2017 7 commits
    • Marko Mäkelä's avatar
      Follow-up to MDEV-13407 innodb.drop_table_background failed in buildbot with... · 88aff5f4
      Marko Mäkelä authored
      Follow-up to MDEV-13407 innodb.drop_table_background failed in buildbot with "Tablespace for table exists"
      
      The InnoDB background DROP TABLE queue is something that we should
      really remove, but are unable to until we remove dict_operation_lock
      so that DDL and DML operations can be combined in a single transaction.
      
      Because the queue is not persistent, it is not crash-safe. We should
      in some way ensure that the deferred-dropped tables will be dropped
      after server restart.
      
      The existence of two separate transactions complicates the error handling
      of CREATE TABLE...SELECT. We should really not break locks in DROP TABLE.
      
      Our solution to these problems is to rename the table to a temporary
      name, and to drop such-named tables on InnoDB startup. Also, the
      queue will use table IDs instead of names from now on.
      
      check-testcase.test: Ignore #sql-ib*.ibd files, because tables may enter
      the background DROP TABLE queue shortly before the test finishes.
      
      innodb.drop_table_background: Test CREATE...SELECT and the creation of
      tables whose file name starts with #sql-ib.
      
      innodb.alter_crash: Adjust the recovery, now that the #sql-ib tables
      will be dropped on InnoDB startup.
      
      row_mysql_drop_garbage_tables(): New function, to drop all #sql-ib tables
      on InnoDB startup.
      
      row_drop_table_for_mysql_in_background(): Remove an unnecessary and
      misplaced call to log_buffer_flush_to_disk(). (The call should have been
      after the transaction commit. We do not care about flushing the redo log
      here, because the table would be dropped again at server startup.)
      
      Remove the entry from the list after the table no longer exists.
      
      If server shutdown has been initiated, empty the list without actually
      dropping any tables. They will be dropped again on startup.
      
      row_drop_table_for_mysql(): Do not call lock_remove_all_on_table().
      Instead, if locks exist, defer the DROP TABLE until they do not exist.
      If the table name does not start with #sql-ib, rename it to that prefix
      before adding it to the background DROP TABLE queue.
      88aff5f4
    • Marko Mäkelä's avatar
      Merge 10.2 into bb-10.2-ext · 028e91f3
      Marko Mäkelä authored
      028e91f3
    • Marko Mäkelä's avatar
      Merge 10.1 to 10.2 · 8d70097c
      Marko Mäkelä authored
      Follow-up fix to MDEV-14008: Let Field_double::val_uint() silently
      return 0 on error
      8d70097c
    • Jan Lindström's avatar
      Fix galera.view test case crash. · 252e690c
      Jan Lindström authored
      WSREP_TO_ISOLATION_BEGIN() call must be after view name is back
      on tables list.
      252e690c
    • Galina Shalygina's avatar
      MDEV-14629: failing assertion when a user-defined variable is defined by the recursive CTE · 079c3599
      Galina Shalygina authored
      During the user-defined variable defined by the recursive CTE handling procedure
      check_dependencies_in_with_clauses that checks dependencies between the tables
      that are defined in the CTE and find recursive definitions wasn't called.
      079c3599
    • Daniel Black's avatar
    • Daniel Black's avatar
      64f1fab0
  5. 18 Dec, 2017 12 commits
  6. 17 Dec, 2017 2 commits
    • Alexey Botchkov's avatar
      MDEV-14593 human-readable XA RECOVER. · 0acac4fe
      Alexey Botchkov authored
              The 'data' field in the XA RECOVER resultset changed
              to be charset_bin. It seems to me right and also
              --binary-as-hex starts working.  The XA RECOVER FORMAT='SQL' option
              implemented.  It returns the XID string that fits to be an argument for the
              XA ... statements.
      0acac4fe
    • Monty's avatar
      Fixed memory leak in my_rocks · 06f0b23a
      Monty authored
      rocksdb_sys_vars.rocksdb_update_cf_options_basic.test failed with
      reports about not freed memory.
      06f0b23a
  7. 16 Dec, 2017 2 commits
  8. 15 Dec, 2017 1 commit
    • Sergei Petrunia's avatar
      MDEV-14293: MyRocks lacks basic functionality · 64b11e61
      Sergei Petrunia authored
      The error
        "Unsupported collation on string indexed column %s Use
          binary collation (latin1_bin, binary, utf8_bin)."
      
      is misleading. Change it:
      - It is now a warning
      - It is printed only for collations that do not support index-only access
        (reversible collations that use unpack_info are ok)
      - The new warning text is:
      
        Indexed column %s.%s uses a collation that does not allow index-only
        access in secondary key and has reduced disk space efficiency
        in primary key.
      64b11e61
  9. 14 Dec, 2017 5 commits
  10. 13 Dec, 2017 5 commits