shell腳本自動修復(fù)mysql損壞的表
問題描述:最近查看mysql數(shù)據(jù)庫服務(wù)器日志,老發(fā)現(xiàn)有表損壞的錯誤日志,比如:120724 7:30:48 [ERROR] /data/soft/mysql/libexec/mysqld: Table './blog/wp_links' is marked as crashed and last (automatic?) repair failed 手動修復(fù)了表后正常了,沒過幾天又發(fā)現(xiàn)出現(xiàn)錯誤。
解決方法:于是就寫了個腳本來自動修復(fù)。是根據(jù)一定時間檢測一次日志,如果有這樣的錯誤記錄時,就對出錯的表進行修復(fù)來達到自動修復(fù)的目的,為了防止日志中錯誤記錄的重復(fù)執(zhí)行,每次檢測完日志后特將日志文件清空。
此類腳本的方法其實有很多,只不過這是其中一種而已,有錯誤之處大家提出來,多多指教。
#!/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" ] then for 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_$i if grep "OK" repair_$i >/dev/null then echo "$TIME repair TABLES $i successful!" else echo "$TIME repair TABLES $i Failed!" fi rm -rf repair_$i done else echo "There is no need to repair the table!" fi :>$LOG_PATH
通過這篇文章大家應(yīng)該知道shell腳本是如何自動修復(fù)mysql損壞的表了吧,希望大家喜歡。
- Shell下實現(xiàn)免密碼快速登陸MySQL數(shù)據(jù)庫的方法
- MySQL數(shù)據(jù)庫的shell腳本自動備份
- Centos7安裝 mysql5.6.29 shell腳本
- MySQL5.7安裝過程并重置root密碼的方法(shell 腳本)
- 實戰(zhàn)模擬監(jiān)控MySQL服務(wù)shell腳本小結(jié)
- MySQL的一些功能實用的Linux shell腳本分享
- CentOS下編寫shell腳本來監(jiān)控MySQL主從復(fù)制的教程
- linux下mysql如何自動備份shell腳本
- 一個簡單的MySQL備份Shell腳本
- Shell腳本檢查IP格式及mysql操作實例
- 用shell寫一個mysql數(shù)據(jù)備份腳本
相關(guān)文章
一天一個shell命令 linux文本內(nèi)容操作系列-awk命令詳解
awk是一個強大的文本分析工具,相對于grep的查找,sed的編輯,awk在其對數(shù)據(jù)分析并生成報告時,顯得尤為強大。簡單來說awk就是把文件逐行的讀入,以空格為默認分隔符將每行切片,切開的部分再進行各種分析處理2016-06-06Shell腳本實現(xiàn)的單機流量統(tǒng)計功能
這篇文章主要介紹了Shell腳本實現(xiàn)的單機流量統(tǒng)計功能,本文給出實現(xiàn)代碼和使用方法,及運行結(jié)果,需要的朋友可以參考下2014-11-11Linux應(yīng)用調(diào)試之strace命令詳解
strace常用來跟蹤進程執(zhí)行時的系統(tǒng)調(diào)用和所接收的信號。下面通過本文給大家分享Linux應(yīng)用調(diào)試之strace命令,需要的朋友參考下吧2017-12-12