MYSQL中實(shí)用shell腳本有哪些

小編給大家分享一下MySQL中實(shí)用shell腳本有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)是專業(yè)的積石山保安族東鄉(xiāng)族網(wǎng)站建設(shè)公司,積石山保安族東鄉(xiāng)族接單;提供成都網(wǎng)站建設(shè)、成都做網(wǎng)站,網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行積石山保安族東鄉(xiāng)族網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!

提取mysql的error信息并報(bào)警,可以按下面步驟:
##變量設(shè)置##
mark=`date +%Y%m%d%H%M`
error_file=/data/mysql/data/error.log
bak_file=/tmp/error_bak.log
report_file=/tmp/error_rport.log

###沒有error.bak就建一個(gè),提取error字段信息到 ${report_file(這邊用>>是為了假設(shè)后面發(fā)郵件失敗,需要保留error信息);讀取${error_file}追加到${bak_file}(相當(dāng)于備份);清空${error_file}
[ ! -f ${bak_file} ] && touch ${bak_file}
[ ! -f ${report_file} ] && touch ${report_file}
cat ${error_file} | grep "\[ERROR\]"  >>  ${report_file}    &&     cat ${error_file} >>  ${bak_file}    &&      > ${error_file}

###檢查 ${report_file大小,如果大于0(說明有error信息),則發(fā)郵件,然后清空 ${report_file}
logsize= `du  -b  ${report_file} |awk '{print $1}'`
[ $logsize  -gt  0  ]     &&   /usr/local/bin/sendEmail ...   &&     > ${report_file}
上面其實(shí)也可以簡(jiǎn)化為[ -s ${logfile} ]  &&   /usr/local/bin/sendEmail ...   &&     > ${report_file}


實(shí)時(shí)提取Mysql的慢日志并報(bào)警,可以按下面步驟:
##變量設(shè)置##
mark=`date +%Y%m%d%H%M`
process=/tmp/showprocesslist.log
slow=/tmp/slow.log

##輸出processlis到${process}。提取time>5的查詢信息到${slow},用>>是為了假設(shè)后面發(fā)郵件失敗,需要保留slow信息
/usr/local/mysql/bin/mysql -usystem -p'itiaoling.com@123' -e "show full processlist;" | sed 's/\\t\|\\n/ /g'  > ${process}
cat ${process} | awk '($6>=5)  &&  ($6<10) && ($5=="Query") {printf $4" "$7" for "$6" seconds\nDetails:\n"$0}' >> ${slow}
cat ${process} | awk '($6>=60) &&  ($6<65) && ($5=="Query") {printf $4" "$7" for "$6" seconds\nDetails:\n"$0}' >> ${slow} 

##檢查${slow},如果存在且非空,則發(fā)郵件,然后清空 ${slow}
[ -s ${slow} ]     &&   /usr/local/bin/sendEmail ...   &&     > ${slow}


監(jiān)控備份,備份失敗報(bào)警
##變量設(shè)置##
mark=`date +%Y%m%d%H%M`
check=/tmp/check.log
backfile=/backup/crm/ncrm_nobh_antdb_wechat_tiaoling$mark.sql.gz

(/usr/local/mysql/bin/mysqldump -uroot -pxx --default-character-set=utf8 --master-data=1 --single-transaction -R -B test || echo "backup not completed" > ${check}) | (gzip || echo "gzip not completed" > ${check}) > ${backfile}
[ -s ${check} ]  &&   /usr/local/bin/sendEmail ...   &&   > ${check}

以上是“MYSQL中實(shí)用shell腳本有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文題目:MYSQL中實(shí)用shell腳本有哪些
網(wǎng)頁URL:http://muchs.cn/article14/geedde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、Google外貿(mào)網(wǎng)站建設(shè)、用戶體驗(yàn)App設(shè)計(jì)、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)