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ù)一定時間檢測一次日志,如果有這樣的錯誤記錄時,就對出錯的表進(jìn)行修復(fù)來達(dá)到自動修復(fù)的目的,為了防止日志中錯誤記錄的重復(fù)執(zhí)行,每次檢測完日志后特將日志文件清空。
此類腳本的方法其實(shí)有很多,只不過這是其中一種而已,有錯誤之處大家提出來,多多指教。
#!/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損壞的表了吧,希望大家喜歡。
- MySQL有壞快后drop表就crash了的解決方案
- MySQL表數(shù)據(jù)文件損壞導(dǎo)致數(shù)據(jù)庫無法啟動的原因與解決方案
- 解決MySQL數(shù)據(jù)庫意外崩潰導(dǎo)致表數(shù)據(jù)文件損壞無法啟動的問題
- Mysql存儲引擎MyISAM的常見問題(表損壞、無法訪問、磁盤空間不足)
- MySQL數(shù)據(jù)庫INNODB表損壞修復(fù)處理過程分享
- 一次非法關(guān)機(jī)導(dǎo)致mysql數(shù)據(jù)表損壞的實(shí)例解決
- MYSQL數(shù)據(jù)表損壞的原因分析和修復(fù)方法小結(jié)(推薦)
- MySQL數(shù)據(jù)表損壞的正確修復(fù)方案
- Mysql 壞表修復(fù)的幾種解決方案
相關(guān)文章
Shell腳本實(shí)現(xiàn)關(guān)閉多余的tty終端
這篇文章主要介紹了Shell腳本實(shí)現(xiàn)關(guān)閉多余的tty終端,本文腳本適用centos6系統(tǒng),請根據(jù)自己的服務(wù)器系統(tǒng)情況選擇使用,需要的朋友可以參考下2014-12-12
linux shell實(shí)現(xiàn)轉(zhuǎn)換輸入日期的格式
對于用戶輸入日期的合法性檢驗(yàn),是個很重要的問題,這個例子是簡單得取得用戶輸入的日期,并轉(zhuǎn)換為相應(yīng)的格式,但不完美,原因請看后文2016-08-08
智能監(jiān)測自動重啟Apache服務(wù)器的Shell腳本
這篇文章主要介紹了智能監(jiān)測自動重啟Apache服務(wù)器的Shell腳本,實(shí)現(xiàn)監(jiān)控Apache不可用時,第一次強(qiáng)制重啟,第二次郵件通知管理員,需要的朋友可以參考下2014-07-07
淺析Shell腳本中的條件判斷[?]與[[?]]的區(qū)別
在編寫?Shell?腳本時,條件判斷是控制腳本流程的重要手段,Shell?提供了多種方式來進(jìn)行條件判斷,其中[?]和[[?]]是兩種常見的條件測試表達(dá)式,下面我們就來看看兩者的區(qū)別吧2024-12-12

