#!/bin/sh DB_USER="root" DB_PASS="123456" DB_NAME="blog" LOG_PATH="/data/db/errlog.log" TIME=`date +%Y-%m-%d" "%H:%M:%S`TABLES=`/usr/bin/awk "/""repair failed""/ {print $6}" $LOG_PATH | sort -k1n | uniq -c | awk -F """ "{print $2}" | awk -F "/" "{print $3}"` if [ -n "$TABLES" ]thenfor i in `/usr/bin/awk "/""repair failed""/ {print $6}" $LOG_PATH | sort -k1n | uniq -c | awk -F """ "{print $2}" | awk -F "/" "{print $3}"`do /data/soft/mysql/bin/mysql -u$DB_USER -p$DB_PASS $DB_NAME -e "repair TABLE $i" > repair_$iif grep "OK" repair_$i >/dev/null thenecho "$TIME repair TABLES $i successful!" else echo "$TIME repair TABLES $i Failed!" firm -rf repair_$idoneelse echo "There is no need to repair the table!" fi:>$LOG_PATH 
通过这篇文章大家应该知道shell脚本是如何自动修复mysql损坏的表了吧,希望大家喜欢。