小編給大家分享一下MYSQL中實用shell腳本有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設,秀嶼企業(yè)網(wǎng)站建設,秀嶼品牌網(wǎng)站建設,網(wǎng)站定制,秀嶼網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,秀嶼網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。提取mysql的error信息并報警,可以按下面步驟:
##變量設置##
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就建一個,提取error字段信息到 ${report_file(這邊用>>是為了假設后面發(fā)郵件失敗,需要保留error信息);讀取${error_file}追加到${bak_file}(相當于備份);清空${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}
上面其實也可以簡化為[ -s ${logfile} ] && /usr/local/bin/sendEmail ... && > ${report_file}
實時提取Mysql的慢日志并報警,可以按下面步驟:
##變量設置##
mark=`date +%Y%m%d%H%M`
process=/tmp/showprocesslist.log
slow=/tmp/slow.log
##輸出processlis到${process}。提取time>5的查詢信息到${slow},用>>是為了假設后面發(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)控備份,備份失敗報警
##變量設置##
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中實用shell腳本有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)-成都網(wǎng)站建設公司行業(yè)資訊頻道!