Commit 2f0d7240 authored by Michael Widenius's avatar Michael Widenius

Don't delete directory mysql-test/var if we use mysql-test-run --vardir=

Fixed error in Maria unittest
Fixes other issues found by test case for lp:700623 "Aria recovery: ma_blockrec.c:3930: _ma_update_at_original_place: Assertion `block->org_bitmap_value == .."
Fixes lp:670356 "Aria table "is marked as crashed and should be repaired"



mysql-test/lib/v1/mysql-test-run.pl:
  Don't delete directory mysql-test/var if we use mysql-test-run --vardir=
mysql-test/mysql-test-run.pl:
  Don't delete directory mysql-test/var if we use mysql-test-run --vardir=
  (Needed to be able to run multiple concurrent mysql-test-run's/randgen on the same server)
  Added extra supression
storage/maria/ma_pagecache.c:
  Removed duplicate DBUG_PRINT information
  Added KEYCACHE_PRINT for printing information that was already printed to DBUG log (to get rid of some duplicated output)
  More comments
  Fixed bug that caused page block to be used by two treads at the same time (with different page information)
  Mark block->status with PCBLOCK_DIRECT_W independent of the block is changed or not. (Safety fix)
storage/maria/maria_chk.c:
  Better --help
storage/maria/unittest/ma_test_recovery.pl:
  Ignore differences in 'recover time'.
  Fixed error in Maria unittest
parent 90741c0d
...@@ -2407,8 +2407,8 @@ sub remove_stale_vardir () { ...@@ -2407,8 +2407,8 @@ sub remove_stale_vardir () {
# Remove the var/ dir in mysql-test dir if any # Remove the var/ dir in mysql-test dir if any
# this could be an old symlink that shouldn't be there # this could be an old symlink that shouldn't be there
mtr_verbose("Removing $default_vardir"); # mtr_verbose("Removing $default_vardir");
mtr_rmtree($default_vardir); # mtr_rmtree($default_vardir);
# Remove the "var" dir # Remove the "var" dir
mtr_verbose("Removing $opt_vardir/"); mtr_verbose("Removing $opt_vardir/");
......
...@@ -2290,10 +2290,10 @@ sub remove_stale_vardir () { ...@@ -2290,10 +2290,10 @@ sub remove_stale_vardir () {
# Running with "var" in some other place # Running with "var" in some other place
# #
# Remove the var/ dir in mysql-test dir if any # Don't remove the var/ dir in mysql-test dir as it may be in
# this could be an old symlink that shouldn't be there # use by another mysql-test-run run with --vardir
mtr_verbose("Removing $default_vardir"); # mtr_verbose("Removing $default_vardir");
rmtree($default_vardir); # rmtree($default_vardir);
# Remove the "var" dir # Remove the "var" dir
mtr_verbose("Removing $opt_vardir/"); mtr_verbose("Removing $opt_vardir/");
...@@ -4315,6 +4315,7 @@ sub extract_warning_lines ($) { ...@@ -4315,6 +4315,7 @@ sub extract_warning_lines ($) {
qr/Plugin 'ndbcluster' will be forced to shutdown/, qr/Plugin 'ndbcluster' will be forced to shutdown/,
qr/InnoDB: Error: in ALTER TABLE `test`.`t[12]`/, qr/InnoDB: Error: in ALTER TABLE `test`.`t[12]`/,
qr/InnoDB: Error: table `test`.`t[12]` does not exist in the InnoDB internal/, qr/InnoDB: Error: table `test`.`t[12]` does not exist in the InnoDB internal/,
qr/InnoDB: Warning: a long semaphore wait:/,
qr/Slave: Unknown table 't1' Error_code: 1051/, qr/Slave: Unknown table 't1' Error_code: 1051/,
qr/Slave SQL:.*(Error_code: [[:digit:]]+|Query:.*)/, qr/Slave SQL:.*(Error_code: [[:digit:]]+|Query:.*)/,
qr/slave SQL thread aborted/, qr/slave SQL thread aborted/,
......
...@@ -97,9 +97,9 @@ ...@@ -97,9 +97,9 @@
#define PCBLOCK_INFO(B) \ #define PCBLOCK_INFO(B) \
DBUG_PRINT("info", \ DBUG_PRINT("info", \
("block: 0x%lx fd: %lu page: %lu s: %0x hshL: " \ ("block: 0x%lx fd: %lu page: %lu status: 0x%x " \
" 0x%lx req: %u/%u wrlocks: %u rdlocks %u " \ "hshL: 0x%lx requests: %u/%u wrlocks: %u rdlocks: %u " \
"rdlocks_q: %u pins: %u status: %u type: %s", \ "rdlocks_q: %u pins: %u type: %s", \
(ulong)(B), \ (ulong)(B), \
(ulong)((B)->hash_link ? \ (ulong)((B)->hash_link ? \
(B)->hash_link->file.file : \ (B)->hash_link->file.file : \
...@@ -107,14 +107,14 @@ ...@@ -107,14 +107,14 @@
(ulong)((B)->hash_link ? \ (ulong)((B)->hash_link ? \
(B)->hash_link->pageno : \ (B)->hash_link->pageno : \
0), \ 0), \
(B)->status, \ (uint) (B)->status, \
(ulong)(B)->hash_link, \ (ulong)(B)->hash_link, \
(uint) (B)->requests, \ (uint) (B)->requests, \
(uint)((B)->hash_link ? \ (uint)((B)->hash_link ? \
(B)->hash_link->requests : \ (B)->hash_link->requests : \
0), \ 0), \
(B)->wlocks, (B)->rlocks, (B)->rlocks_queue, \ (B)->wlocks, (B)->rlocks, (B)->rlocks_queue, \
(uint)(B)->pins, (uint)(B)->status, \ (uint)(B)->pins, \
page_cache_page_type_str[(B)->type])) page_cache_page_type_str[(B)->type]))
/* TODO: put it to my_static.c */ /* TODO: put it to my_static.c */
...@@ -155,8 +155,10 @@ struct st_pagecache_hash_link ...@@ -155,8 +155,10 @@ struct st_pagecache_hash_link
#define PCBLOCK_READ 2 /* the is page in the block buffer */ #define PCBLOCK_READ 2 /* the is page in the block buffer */
/* /*
A tread is reading the data to the page. The page is not yet ready A tread is reading the data to the page.
to be used. If the page contained old changed data, it will be written out with
this state set on the block.
The page is not yet ready to be used for reading.
*/ */
#define PCBLOCK_IN_SWITCH 4 #define PCBLOCK_IN_SWITCH 4
/* /*
...@@ -164,7 +166,8 @@ struct st_pagecache_hash_link ...@@ -164,7 +166,8 @@ struct st_pagecache_hash_link
the page to be pinned or written to. the page to be pinned or written to.
(Reads that copies the block can still continue). (Reads that copies the block can still continue).
This state happens when another thread is waiting for readers to finish This state happens when another thread is waiting for readers to finish
to read/write new data to the block. to read data to the block (after the block, if it was changed, has been
flushed out to disk).
*/ */
#define PCBLOCK_REASSIGNED 8 #define PCBLOCK_REASSIGNED 8
#define PCBLOCK_IN_FLUSH 16 /* block is in flush operation */ #define PCBLOCK_IN_FLUSH 16 /* block is in flush operation */
...@@ -527,6 +530,7 @@ static void pagecache_debug_print _VARARGS((const char *fmt, ...)); ...@@ -527,6 +530,7 @@ static void pagecache_debug_print _VARARGS((const char *fmt, ...));
#endif /* defined(PAGECACHE_DEBUG_LOG) */ #endif /* defined(PAGECACHE_DEBUG_LOG) */
#if defined(PAGECACHE_DEBUG_LOG) && defined(PAGECACHE_DEBUG) #if defined(PAGECACHE_DEBUG_LOG) && defined(PAGECACHE_DEBUG)
#define KEYCACHE_PRINT(l, m) KEYCACHE_DBUG_PRINT(l,m)
#define KEYCACHE_DBUG_PRINT(l, m) \ #define KEYCACHE_DBUG_PRINT(l, m) \
{ if (pagecache_debug_log) \ { if (pagecache_debug_log) \
fprintf(pagecache_debug_log, "%s: ", l); \ fprintf(pagecache_debug_log, "%s: ", l); \
...@@ -537,6 +541,7 @@ static void pagecache_debug_print _VARARGS((const char *fmt, ...)); ...@@ -537,6 +541,7 @@ static void pagecache_debug_print _VARARGS((const char *fmt, ...));
fclose(pagecache_debug_log); \ fclose(pagecache_debug_log); \
assert(a); } assert(a); }
#else #else
#define KEYCACHE_PRINT(l, m)
#define KEYCACHE_DBUG_PRINT(l, m) DBUG_PRINT(l, m) #define KEYCACHE_DBUG_PRINT(l, m) DBUG_PRINT(l, m)
#define KEYCACHE_DBUG_ASSERT(a) DBUG_ASSERT(a) #define KEYCACHE_DBUG_ASSERT(a) DBUG_ASSERT(a)
#endif /* defined(PAGECACHE_DEBUG_LOG) && defined(PAGECACHE_DEBUG) */ #endif /* defined(PAGECACHE_DEBUG_LOG) && defined(PAGECACHE_DEBUG) */
...@@ -560,6 +565,7 @@ static long pagecache_thread_id; ...@@ -560,6 +565,7 @@ static long pagecache_thread_id;
#define KEYCACHE_THREAD_TRACE_END(l) KEYCACHE_DBUG_PRINT(l,("")) #define KEYCACHE_THREAD_TRACE_END(l) KEYCACHE_DBUG_PRINT(l,(""))
#endif /* THREAD */ #endif /* THREAD */
#else #else
#defien KEYCACHE_PRINT(l,m)
#define KEYCACHE_THREAD_TRACE_BEGIN(l) #define KEYCACHE_THREAD_TRACE_BEGIN(l)
#define KEYCACHE_THREAD_TRACE_END(l) #define KEYCACHE_THREAD_TRACE_END(l)
#define KEYCACHE_THREAD_TRACE(l) #define KEYCACHE_THREAD_TRACE(l)
...@@ -1408,7 +1414,7 @@ static void link_block(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block, ...@@ -1408,7 +1414,7 @@ static void link_block(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block,
static void unlink_block(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block) static void unlink_block(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block)
{ {
DBUG_ENTER("unlink_block"); DBUG_ENTER("unlink_block");
DBUG_PRINT("unlink_block", ("unlink 0x%lx", (ulong)block)); DBUG_PRINT("pagecache", ("unlink 0x%lx", (ulong)block));
DBUG_ASSERT(block->next_used != NULL); DBUG_ASSERT(block->next_used != NULL);
if (block->next_used == block) if (block->next_used == block)
{ {
...@@ -1432,7 +1438,7 @@ static void unlink_block(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block) ...@@ -1432,7 +1438,7 @@ static void unlink_block(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block)
#if defined(PAGECACHE_DEBUG) #if defined(PAGECACHE_DEBUG)
KEYCACHE_DBUG_ASSERT(pagecache->blocks_available != 0); KEYCACHE_DBUG_ASSERT(pagecache->blocks_available != 0);
pagecache->blocks_available--; pagecache->blocks_available--;
KEYCACHE_DBUG_PRINT("unlink_block", KEYCACHE_DBUG_PRINT("pagecache",
("unlinked block: 0x%lx (%u) status: %x #requests: %u #available: %u", ("unlinked block: 0x%lx (%u) status: %x #requests: %u #available: %u",
(ulong)block, PCBLOCK_NUMBER(pagecache, block), (ulong)block, PCBLOCK_NUMBER(pagecache, block),
block->status, block->status,
...@@ -1460,9 +1466,6 @@ static void reg_requests(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block, ...@@ -1460,9 +1466,6 @@ static void reg_requests(PAGECACHE *pagecache, PAGECACHE_BLOCK_LINK *block,
int count) int count)
{ {
DBUG_ENTER("reg_requests"); DBUG_ENTER("reg_requests");
DBUG_PRINT("enter", ("block: 0x%lx (%u) status: %x reqs: %u",
(ulong)block, PCBLOCK_NUMBER(pagecache, block),
block->status, block->requests));
PCBLOCK_INFO(block); PCBLOCK_INFO(block);
if (! block->requests) if (! block->requests)
/* First request for the block unlinks it */ /* First request for the block unlinks it */
...@@ -1694,8 +1697,8 @@ static PAGECACHE_HASH_LINK *get_present_hash_link(PAGECACHE *pagecache, ...@@ -1694,8 +1697,8 @@ static PAGECACHE_HASH_LINK *get_present_hash_link(PAGECACHE *pagecache,
int cnt; int cnt;
#endif #endif
DBUG_ENTER("get_present_hash_link"); DBUG_ENTER("get_present_hash_link");
DBUG_PRINT("enter", ("fd: %u pos: %lu", (uint) file->file, (ulong) pageno));
KEYCACHE_DBUG_PRINT("get_present_hash_link", ("fd: %u pos: %lu", KEYCACHE_PRINT("get_present_hash_link", ("fd: %u pos: %lu",
(uint) file->file, (ulong) pageno)); (uint) file->file, (ulong) pageno));
/* /*
...@@ -1858,12 +1861,10 @@ static PAGECACHE_BLOCK_LINK *find_block(PAGECACHE *pagecache, ...@@ -1858,12 +1861,10 @@ static PAGECACHE_BLOCK_LINK *find_block(PAGECACHE *pagecache,
PAGECACHE_BLOCK_LINK *block; PAGECACHE_BLOCK_LINK *block;
int error= 0; int error= 0;
int page_status; int page_status;
DBUG_ENTER("find_block"); DBUG_ENTER("find_block");
KEYCACHE_THREAD_TRACE("find_block:begin"); DBUG_PRINT("enter", ("fd: %d pos: %lu wrmode: %d block_is_copied: %d",
DBUG_PRINT("enter", ("fd: %d pos: %lu wrmode: %d", file->file, (ulong) pageno, wrmode, block_is_copied));
file->file, (ulong) pageno, wrmode)); KEYCACHE_PRINT("find_block", ("fd: %d pos: %lu wrmode: %d",
KEYCACHE_DBUG_PRINT("find_block", ("fd: %d pos: %lu wrmode: %d",
file->file, (ulong) pageno, file->file, (ulong) pageno,
wrmode)); wrmode));
#if !defined(DBUG_OFF) && defined(EXTRA_DEBUG) #if !defined(DBUG_OFF) && defined(EXTRA_DEBUG)
...@@ -2036,9 +2037,9 @@ static PAGECACHE_BLOCK_LINK *find_block(PAGECACHE *pagecache, ...@@ -2036,9 +2037,9 @@ static PAGECACHE_BLOCK_LINK *find_block(PAGECACHE *pagecache,
block->hash_link= hash_link; block->hash_link= hash_link;
hash_link->block= block; hash_link->block= block;
page_status= PAGE_TO_BE_READ; page_status= PAGE_TO_BE_READ;
DBUG_PRINT("info", ("page to be read set for page 0x%lx", DBUG_PRINT("info", ("page to be read set for page 0x%lx (%u)",
(ulong)block)); (ulong) block, PCBLOCK_NUMBER(pagecache, block)));
KEYCACHE_DBUG_PRINT("find_block", KEYCACHE_PRINT("find_block",
("got free or never used block %u", ("got free or never used block %u",
PCBLOCK_NUMBER(pagecache, block))); PCBLOCK_NUMBER(pagecache, block)));
} }
...@@ -2197,7 +2198,7 @@ static PAGECACHE_BLOCK_LINK *find_block(PAGECACHE *pagecache, ...@@ -2197,7 +2198,7 @@ static PAGECACHE_BLOCK_LINK *find_block(PAGECACHE *pagecache,
("block: 0x%lx fd: %u pos: %lu block->status: %u page_status: %u", ("block: 0x%lx fd: %u pos: %lu block->status: %u page_status: %u",
(ulong) block, (uint) file->file, (ulong) block, (uint) file->file,
(ulong) pageno, block->status, (uint) page_status)); (ulong) pageno, block->status, (uint) page_status));
KEYCACHE_DBUG_PRINT("find_block", KEYCACHE_PRINT("find_block",
("block: 0x%lx fd: %d pos: %lu block->status: %u page_status: %d", ("block: 0x%lx fd: %d pos: %lu block->status: %u page_status: %d",
(ulong) block, (ulong) block,
file->file, (ulong) pageno, block->status, file->file, (ulong) pageno, block->status,
...@@ -3367,8 +3368,8 @@ uchar *pagecache_read(PAGECACHE *pagecache, ...@@ -3367,8 +3368,8 @@ uchar *pagecache_read(PAGECACHE *pagecache,
/* See NOTE for pagecache_unlock about registering requests. */ /* See NOTE for pagecache_unlock about registering requests. */
reg_request= ((new_pin == PAGECACHE_PIN_LEFT_UNPINNED) || reg_request= ((new_pin == PAGECACHE_PIN_LEFT_UNPINNED) ||
(new_pin == PAGECACHE_PIN)); (new_pin == PAGECACHE_PIN));
block= find_block(pagecache, file, pageno, level, buff != 0, block= find_block(pagecache, file, pageno, level,
lock == PAGECACHE_LOCK_WRITE, lock == PAGECACHE_LOCK_WRITE, buff != 0,
reg_request, &page_st); reg_request, &page_st);
DBUG_PRINT("info", ("Block type: %s current type %s", DBUG_PRINT("info", ("Block type: %s current type %s",
page_cache_page_type_str[block->type], page_cache_page_type_str[block->type],
...@@ -3421,8 +3422,7 @@ uchar *pagecache_read(PAGECACHE *pagecache, ...@@ -3421,8 +3422,7 @@ uchar *pagecache_read(PAGECACHE *pagecache,
buff= block->buffer; buff= block->buffer;
/* possibly we will write here (resolved on unlock) */ /* possibly we will write here (resolved on unlock) */
if ((lock == PAGECACHE_LOCK_WRITE || if ((lock == PAGECACHE_LOCK_WRITE ||
lock == PAGECACHE_LOCK_LEFT_WRITELOCKED) && lock == PAGECACHE_LOCK_LEFT_WRITELOCKED))
!(block->status & PCBLOCK_CHANGED))
{ {
block->status|= PCBLOCK_DIRECT_W; block->status|= PCBLOCK_DIRECT_W;
DBUG_PRINT("info", ("Set PCBLOCK_DIRECT_W for block: 0x%lx", DBUG_PRINT("info", ("Set PCBLOCK_DIRECT_W for block: 0x%lx",
...@@ -4323,15 +4323,13 @@ static int flush_cached_blocks(PAGECACHE *pagecache, ...@@ -4323,15 +4323,13 @@ static int flush_cached_blocks(PAGECACHE *pagecache,
PAGECACHE_LOCK_READ, PAGECACHE_PIN, FALSE)) PAGECACHE_LOCK_READ, PAGECACHE_PIN, FALSE))
DBUG_ASSERT(0); DBUG_ASSERT(0);
KEYCACHE_DBUG_PRINT("flush_cached_blocks", KEYCACHE_PRINT("flush_cached_blocks",
("block: %u (0x%lx) to be flushed", ("block: %u (0x%lx) to be flushed",
PCBLOCK_NUMBER(pagecache, block), (ulong)block)); PCBLOCK_NUMBER(pagecache, block), (ulong)block));
DBUG_PRINT("info", ("block: %u (0x%lx) to be flushed", DBUG_PRINT("info", ("block: %u (0x%lx) to be flushed",
PCBLOCK_NUMBER(pagecache, block), (ulong)block)); PCBLOCK_NUMBER(pagecache, block), (ulong)block));
PCBLOCK_INFO(block); PCBLOCK_INFO(block);
DBUG_PRINT("info", ("block: %u (0x%lx) pins: %u",
PCBLOCK_NUMBER(pagecache, block), (ulong)block,
block->pins));
/** /**
@todo IO If page is contiguous with next page to flush, group flushes @todo IO If page is contiguous with next page to flush, group flushes
in one single my_pwrite(). in one single my_pwrite().
......
...@@ -345,9 +345,11 @@ static struct my_option my_long_options[] = ...@@ -345,9 +345,11 @@ static struct my_option my_long_options[] =
&opt_transaction_logging, &opt_transaction_logging, &opt_transaction_logging, &opt_transaction_logging,
0, GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0}, 0, GET_BOOL, NO_ARG, 0, 0, 0, 0, 0, 0},
{"update-state", 'U', {"update-state", 'U',
"Mark tables as crashed if any errors were found and clean if check didn't " "Mark tables as crashed if any errors were found and clean if check "
"find any errors. This allows one to get rid of warnings like 'table not " "didn't find any errors but table was marked as 'not clean' before. This "
"properly closed'", "allows one to get rid of warnings like 'table not properly closed'. "
"If table was updated, update also the timestamp for when check was made. "
"This option is on by default!",
&opt_update_state, &opt_update_state, 0, GET_BOOL, NO_ARG, &opt_update_state, &opt_update_state, 0, GET_BOOL, NO_ARG,
1, 0, 0, 0, 0, 0}, 1, 0, 0, 0, 0, 0},
{"unpack", 'u', {"unpack", 'u',
...@@ -485,7 +487,13 @@ static void usage(void) ...@@ -485,7 +487,13 @@ static void usage(void)
-m, --medium-check Faster than extend-check, but only finds 99.99% of\n\ -m, --medium-check Faster than extend-check, but only finds 99.99% of\n\
all errors. Should be good enough for most cases.\n\ all errors. Should be good enough for most cases.\n\
-T, --read-only Don't mark table as checked.\n\ -T, --read-only Don't mark table as checked.\n\
-U, --update-state Mark tables as crashed if you find any errors.\n\ -U, --update-state Mark tables as crashed if any errors were found and\n\
clean if check didn't find any errors but table was\n\
marked as 'not clean' before. This allows one to get\n\
rid of warnings like 'table not properly closed'. If\n\
table was updated, update also the timestamp for when\n\
the check was made. This option is on by default!\n\
use --skip-update-state to disable.\n\
--warning-for-wrong-transaction-id\n\ --warning-for-wrong-transaction-id\n\
Give a warning if we find a transaction id in the table that is bigger\n\ Give a warning if we find a transaction id in the table that is bigger\n\
than what exists in the control file. Use --skip-... to disable warning\n\ than what exists in the control file. Use --skip-... to disable warning\n\
......
...@@ -114,7 +114,7 @@ sub main ...@@ -114,7 +114,7 @@ sub main
die("can't guess table name"); die("can't guess table name");
} }
$com= "$maria_exe_path/maria_chk$suffix -dvv $table "; $com= "$maria_exe_path/maria_chk$suffix -dvv $table ";
$com.= "| grep -v \"Creation time:\" | grep -v \"file length\" | grep -v \"LSNs:\" | grep -v \"UUID:\""; $com.= "| grep -v \"Creation time:\" | grep -v \"recover time:\" | grep -v \"file length\" | grep -v \"LSNs:\" | grep -v \"UUID:\"";
$com.= "> $tmp/maria_chk_message.good.txt 2>&1"; $com.= "> $tmp/maria_chk_message.good.txt 2>&1";
my_exec($com); my_exec($com);
my $checksum= my_exec("$maria_exe_path/maria_chk$suffix -dss $table"); my $checksum= my_exec("$maria_exe_path/maria_chk$suffix -dss $table");
...@@ -197,7 +197,7 @@ sub main ...@@ -197,7 +197,7 @@ sub main
die("can't guess table name"); die("can't guess table name");
} }
$com= "$maria_exe_path/maria_chk$suffix -dvv $table "; $com= "$maria_exe_path/maria_chk$suffix -dvv $table ";
$com.= "| grep -v \"Creation time:\" | grep -v \"file length\" | grep -v \"LSNs:\" | grep -v \"UUID:\" "; $com.= "| grep -v \"Creation time:\" | grep -v \"recover time:\" | grep -v \"recover time:\" |grep -v \"file length\" | grep -v \"LSNs:\" | grep -v \"UUID:\" ";
$com.= "> $tmp/maria_chk_message.good.txt 2>&1"; $com.= "> $tmp/maria_chk_message.good.txt 2>&1";
$res= my_exec($com); $res= my_exec($com);
print MY_LOG $res; print MY_LOG $res;
...@@ -296,7 +296,7 @@ sub check_table_is_same ...@@ -296,7 +296,7 @@ sub check_table_is_same
print "checking if table $table has changed\n"; print "checking if table $table has changed\n";
} }
$com= "$maria_exe_path/maria_chk$suffix -dvv $table | grep -v \"Creation time:\" "; $com= "$maria_exe_path/maria_chk$suffix -dvv $table | grep -v \"Creation time:\" | grep -v \"recover time:\"";
$com.= "| grep -v \"file length\" | grep -v \"LSNs:\" | grep -v \"UUID:\" > $tmp/maria_chk_message.txt 2>&1"; $com.= "| grep -v \"file length\" | grep -v \"LSNs:\" | grep -v \"UUID:\" > $tmp/maria_chk_message.txt 2>&1";
$res= `$com`; $res= `$com`;
print MY_LOG $res; print MY_LOG $res;
...@@ -415,7 +415,7 @@ sub physical_cmp ...@@ -415,7 +415,7 @@ sub physical_cmp
# save original tables to restore them later # save original tables to restore them later
copy("$table.MAD", "$tmp/before_zerofill$table_no.MAD") || die(); copy("$table.MAD", "$tmp/before_zerofill$table_no.MAD") || die();
copy("$table.MAI", "$tmp/before_zerofill$table_no.MAI") || die(); copy("$table.MAI", "$tmp/before_zerofill$table_no.MAI") || die();
$com= "$maria_exe_path/maria_chk$suffix -ss --zerofill-keep-lsn $table"; $com= "$maria_exe_path/maria_chk$suffix -ss --zerofill-keep-lsn --skip-update-state $table";
$res= `$com`; $res= `$com`;
print MY_LOG $res; print MY_LOG $res;
$table_no= $table_no + 1; $table_no= $table_no + 1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment