佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > shell腳本自動修復mysql損壞的表

shell腳本自動修復mysql損壞的表

熱門標簽:服務(wù)外包 網(wǎng)站排名優(yōu)化 地方門戶網(wǎng)站 Linux服務(wù)器 AI電銷 鐵路電話系統(tǒng) 百度競價排名 呼叫中心市場需求

問題描述:最近查看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ā)現(xiàn)出現(xiàn)錯誤。

解決方法:于是就寫了個腳本來自動修復。是根據(jù)一定時間檢測一次日志,如果有這樣的錯誤記錄時,就對出錯的表進行修復來達到自動修復的目的,為了防止日志中錯誤記錄的重復執(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 

通過這篇文章大家應該知道shell腳本是如何自動修復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主從復制的教程
  • linux下mysql如何自動備份shell腳本
  • 一個簡單的MySQL備份Shell腳本
  • Shell腳本檢查IP格式及mysql操作實例
  • 用shell寫一個mysql數(shù)據(jù)備份腳本

標簽:湘潭 蘭州 湖南 銅川 黃山 衡水 崇左 仙桃

巨人網(wǎng)絡(luò)通訊聲明:本文標題《shell腳本自動修復mysql損壞的表》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    商南县| 岳阳县| 含山县| 嘉兴市| 高阳县| 灵川县| 新绛县| 自治县| 炎陵县| 景谷| 庆云县| 盐城市| 武宁县| 三穗县| 济南市| 西昌市| 乌恰县| 承德市| 禹州市| 湘潭市| 高雄市| 天祝| 阿勒泰市| 苏尼特左旗| 临漳县| 乐都县| 莫力| 巴南区| 连云港市| 康保县| 钟祥市| 民和| 张家界市| 衢州市| 新龙县| 张家口市| 齐河县| 金昌市| 镇原县| 巴马| 彭阳县|