mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 09:14:17 +01:00
d6d63f4844
Make all system tables in mysql directory of type engine=Aria Privilege tables are using transactional=1 Statistical tables are using transactional=0, to allow them to be quickly updated with low overhead. Help tables are also using transactional=0 as these are only updated at init time. Other changes: - Aria store engine is now a required engine - Update comment for Aria tables to reflect their new usage - Fixed that _ma_reset_trn_for_table() removes unlocked table from transaction table list. This was needed to allow one to lock and unlock system tables separately from other tables, for example when reading a procedure from mysql.proc - Don't give a warning when using transactional=1 for engines that is using transactions. This is both logical and also to avoid warnings/errors when doing an alter of a privilege table to InnoDB. - Don't abort on warnings from ALTER TABLE for changes that would be accepted by CREATE TABLE. - New created Aria transactional tables are marked as not movable (as they include create_rename_lsn). - bootstrap.test was changed to kill orignal server, as one can't anymore have two servers started at same time on same data directory and data files. - Disable maria.small_blocksize as one can't anymore change aria block size after system tables are created. - Speed up creation of help tables by using lock tables. - wsrep_sst_resync now also copies Aria redo logs.
111 lines
4.1 KiB
PHP
111 lines
4.1 KiB
PHP
# Maria helper script.
|
|
# Runs recovery, compare with expected table data.
|
|
|
|
# API:
|
|
# 1) set $mms_tname to a string, and $mms_tables to a number N, the script
|
|
# will cover tables mysqltest.$mms_tname1,...$mms_tnameN
|
|
# 2) set $mvr_debug_option to the crash way
|
|
# 3) set $mvr_crash_statement to the statement which will trigger a crash
|
|
# 4) set $mvr_restore_old_snapshot to 1 if you want recovery to run on
|
|
# an old copy of tables and of the control file, 0 for normal recovery.
|
|
# 5) set $mms_compare_physically to 1 if you want a physical byte-for-byte
|
|
# comparison with expected table. Checksum comparison is always done.
|
|
# "mvr" is a namespace for Maria_Verify_Recovery
|
|
|
|
connection admin;
|
|
|
|
# we may do a copy-back of tables before comparison, so save comparison
|
|
# request made by caller:
|
|
let $mms_compare_physically_save=$mms_compare_physically;
|
|
let $mms_compare_physically=0;
|
|
|
|
# warn mtr that mysqld is going to die and should not be restarted immediately
|
|
#append_file $MYSQLTEST_VARDIR/tmp/mysqld.1.expect;
|
|
#wait-maria_verify_recovery.inc
|
|
#EOF
|
|
# todo: remove this "system" and uncomment above when BUG#32296 is fixed
|
|
system echo wait-maria_verify_recovery.inc >> $MYSQLTEST_VARDIR/tmp/mysqld.1.expect;
|
|
|
|
# flush page cache and log, only log, or nothing, and kill mysqld with
|
|
# abort().
|
|
# When we restore an old snapshot, we could just kill mysqld nicely,
|
|
# but that would implicitely commit all work, which the tester may
|
|
# not want (tester may want to observe rollback happening).
|
|
|
|
eval SET SESSION debug_dbug=$mvr_debug_option;
|
|
--echo * crashing mysqld intentionally
|
|
--error 2013
|
|
eval $mvr_crash_statement; # this will crash (DBUG magic)
|
|
|
|
if ($mvr_restore_old_snapshot)
|
|
{
|
|
|
|
# copy snapshot made by maria_make_snapshot_for_feeding_recovery back
|
|
# into datadir.
|
|
|
|
let $mms_table_to_use=$mms_tables;
|
|
let $mms_purpose=feeding_recovery;
|
|
let $mms_reverse_copy=1;
|
|
while ($mms_table_to_use)
|
|
{
|
|
-- source include/maria_make_snapshot.inc
|
|
dec $mms_table_to_use;
|
|
}
|
|
let $mms_reverse_copy=0;
|
|
|
|
# also copy back control file, to force recovery to start from an early
|
|
# point, ignoring further checkpoints.
|
|
-- error 0,1
|
|
remove_file $MYSQLD_DATADIR/$MARIA_LOG/aria_log_control;
|
|
copy_file $MYSQLTEST_VARDIR/tmp/mms_for_$mms_purpose.aria_log_control $MYSQLD_DATADIR/$MARIA_LOG/aria_log_control;
|
|
}
|
|
|
|
--echo * recovery happens
|
|
# let mtr restart mysqld (and thus execute the maria log)
|
|
#append_file $MYSQLTEST_VARDIR/tmp/mysqld.1.expect;
|
|
#restart-maria_verify_recovery.inc
|
|
#EOF
|
|
system echo restart-maria_verify_recovery.inc >> $MYSQLTEST_VARDIR/tmp/mysqld.1.expect;
|
|
|
|
--source include/wait_until_connected_again.inc
|
|
|
|
# Compare that tables of $mms_tables are identical to old.
|
|
# We always compare with CHECKSUM TABLE, and if requested (which makes sense
|
|
# only for testing the REDO phase, as UNDO phase generates new records so new
|
|
# LSNs on pages.) with a physical byte-for-byte comparison.
|
|
let $mms_table_to_use=$mms_tables;
|
|
let $mms_purpose=comparison;
|
|
let $mms_compare_physically=$mms_compare_physically_save;
|
|
while ($mms_table_to_use)
|
|
{
|
|
# the size of the index file is different for with/without encryption
|
|
--replace_result 372 <SIZE> 394 <SIZE>
|
|
eval check table $mms_tname$mms_table_to_use extended;
|
|
--echo * testing that checksum after recovery is as expected
|
|
let $new_checksum=`CHECKSUM TABLE $mms_tname$mms_table_to_use`;
|
|
let $old_checksum=`CHECKSUM TABLE mysqltest_for_$mms_purpose.$mms_tname$mms_table_to_use`;
|
|
# the $ text variables above are of the form "db.tablename\tchecksum",
|
|
# as db differs, we use substring().
|
|
--disable_query_log
|
|
eval select if(substring("$new_checksum",instr("$new_checksum",".t1")) = substring("$old_checksum",instr("$old_checksum",".t1")),"ok","failure") as "Checksum-check";
|
|
--enable_query_log
|
|
# this script may compare physically or do nothing
|
|
-- source include/maria_make_snapshot.inc
|
|
dec $mms_table_to_use;
|
|
}
|
|
|
|
connection default;
|
|
# the effect of "use" is lost after a restart so we are back into db "test"
|
|
use mysqltest;
|
|
|
|
#
|
|
# Ensure that we don't get warnings from mysql.proc (used by check_mysqld)
|
|
#
|
|
|
|
--disable_query_log
|
|
--disable_warnings
|
|
--disable_result_log
|
|
select count(*) from mysql.proc;
|
|
--enable_result_log
|
|
--enable_warnings
|
|
--enable_query_log
|