检查并修复mysql数据库表的具体方法

时间:2022-10-29 14:37:52
  1. #!/bin/sh 
  2. #code by scpman 
  3. #功能:检查并修复mysql数据库表 
  4. #将此脚本加到定时中,脚本执行时,等会读库,列出要修复的所有表,然后计时,开始修复 
  5. #修复过程中将损坏的表记录下来,修复完成后,将损坏的表,发邮件通知。 
  6. fix_logs='/tmp/fix.log' 
  7. user='' 
  8. pass='' 
  9. check_fix() 
  10. dblist=`/usr/bin/find /usr/dlm_db/mysql/ -type d | grep -vE "logs|_[1-9]|*bak|test"| sed -e "s#/usr/dlm_db/mysql/##g"
  11. echo start `date`>$fix_logs 
  12. for dbname in $dblist 
  13. do 
  14. echo $dbname 
  15. for tb_name in `/usr/bin/find /usr/dlm_db/mysql/$dbname -type f | awk -F'/' '{print $NF}' | awk -F'.' '{print $1}' | sort - 
  16. u` 
  17. do 
  18. mysql -u$user -p$pass $dbname<<fff>>$fix_logs 
  19. check table $tb_name; 
  20. repair table $tb_name; 
  21. FFF 
  22. done 
  23. done 
  24. echo `date` done>>$fix_logs 
  25. send_logs() 
  26. msgip=10.0.7.44 
  27. IP=`cat /etc/rc.conf | grep -E "ifconfig_[em1|bce1]" | awk '{print "IP:"$2}'| sed -n 1p ` 
  28. fix_info=`grep -rE "Error|start|done" $fix_logs` 
  29. /usr/bin/logger -p local1.info -h $msgip "the services: $IP mysql_table_fix_info:$fix_info" 
  30. check_fix 
  31. send_logs