forked from Percona-QA/percona-qa
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpquery-recovery.sh
executable file
·70 lines (65 loc) · 3.39 KB
/
pquery-recovery.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#!/bin/bash
PQUERY_PWD=${PWD}
MYSQLD_START_TIMEOUT=60
if [ -z $1 ]; then
echo "No valid parameter passed. Need relative trial directoy setting. Retry.";
echo "Usage example:"
echo "$./pquery-recovery.sh 100 "
exit 1
else
TRIAL=$1
fi
ps -ef | grep $TRIAL |grep mysqld | grep -v grep | awk '{print $2}' | xargs kill -9 > /dev/null 2>&1
# Start mysqld for recovery testing
$PQUERY_PWD/$TRIAL/start_recovery > /dev/null &
BASEDIR=`grep BASEDIR $PQUERY_PWD/$TRIAL/start_recovery | sed 's|^[ \t]*BASEDIR[ \t]*=[ \t]*[ \t]*||'`
for X in $(seq 0 ${MYSQLD_START_TIMEOUT}); do
sleep 1
if ${BASEDIR}/bin/mysqladmin -urecovery -S${PQUERY_PWD}/${TRIAL}/socket.sock ping > /dev/null 2>&1; then
break
fi
done
# Check server startup
if egrep -q "registration as a STORAGE ENGINE failed" $PQUERY_PWD/$TRIAL/log/master.err; then
echo "Recovery error : Storage engine registration failed."
exit 1
elif egrep -q "corrupt|crashed" $PQUERY_PWD/$TRIAL/log/master.err; then
echo "Recovery error : Log message '$_' indicates database corruption."
exit 1
elif egrep -q "device full error|no space left on device" $PQUERY_PWD/$TRIAL/log/master.err; then
echo "Recovery error : Check disk space."
exit 1
elif egrep -q "ready for connections" $PQUERY_PWD/$TRIAL/log/master.err; then
echo "Recovery info : Server Recovery was apparently successful."
fi
dbs=$(${BASEDIR}/bin/mysql --socket=${PQUERY_PWD}/${TRIAL}/socket.sock -urecovery -Bse "select schema_name from information_schema.schemata where schema_name not in ('mysql','information_schema','performance_schema')" )
# Check tables
for i in "${dbs[@]}"; do
tbs=$(${BASEDIR}/bin/mysql --socket=${PQUERY_PWD}/${TRIAL}/socket.sock -urecovery -Bse "select table_name from information_schema.tables where table_schema='$i'")
tbl_array=( $( for i in $tbs ; do echo $i ; done ) )
for j in "${tbl_array[@]}"; do
echo -e "\nVerifying table: $j; database: $i\n"
chk_result=$((${BASEDIR}/bin/mysql --socket=${PQUERY_PWD}/${TRIAL}/socket.sock -urecovery -Bse $i "CHECK TABLE $j EXTENDED") 2>&1)
analyze_result=$((${BASEDIR}/bin/mysql --socket=${PQUERY_PWD}/${TRIAL}/socket.sock -urecovery -Bse $i "ANALYZE TABLE $j") 2>&1)
opt_result=$((${BASEDIR}/bin/mysql --socket=${PQUERY_PWD}/${TRIAL}/socket.sock -urecovery -Bse $i "OPTIMIZE TABLE $j") 2>&1)
repair_result=$((${BASEDIR}/bin/mysql --socket=${PQUERY_PWD}/${TRIAL}/socket.sock -urecovery -Bse $i "REPAIR TABLE $j EXTENDED") 2>&1)
alter_result=$((${BASEDIR}/bin/mysql --socket=${PQUERY_PWD}/${TRIAL}/socket.sock -urecovery -Bse $i "ALTER TABLE $j ENGINE = TokuDB") 2>&1)
ERROR_INFO=""
if echo $chk_result| egrep -q -i "error|corrupt|repaired|invalid|crashed" ; then
ERROR_INFO="Check table error : $chk_result\n"
fi
if echo $analyze_result| egrep -q -i "error|corrupt|repaired|invalid|crashed" ; then
ERROR_INFO="${ERROR_INFO}Analyze table error : $analyze_result\n"
fi
if echo $opt_result| egrep -q -i "error|corrupt|repaired|invalid|crashed" ; then
ERROR_INFO="${ERROR_INFO}Optimize table error : $opt_result\n"
fi
if echo $repair_result| egrep -q -i "error|corrupt|repaired|invalid|crashed" ; then
ERROR_INFO="${ERROR_INFO}Repair table error : $repair_result\n"
fi
if echo $alter_result| egrep -q -i "error|corrupt|repaired|invalid|crashed" ; then
ERROR_INFO="${ERROR_INFO}Alter table error : $alter_result\n"
fi
echo -e "$ERROR_INFO\n"
done
done