監(jiān)控MySQL主從狀態(tài)的shell腳本
分享一個(gè)Linux下,監(jiān)控MySQL主從狀態(tài)及配合企業(yè)微信機(jī)器人報(bào)警的Shell腳本
SLAVE_IP:為監(jiān)控的主機(jī)IP USER:為msyql用戶 PASSWORD:為mysql密碼 WHEREIS_MYSQL:為mysql命令路徑 WEBHOOK:為企業(yè)微信機(jī)器人Webhook地址 wx():為企業(yè)微信機(jī)器人函數(shù) Check_Mysql_Slave():為監(jiān)控腳本主函數(shù)#! /bin/bash#source /etc/profileexport PATH='/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin'SLAVE_IP=`ip add | grep inet | grep brd | awk -F / ’{print $1}’ | awk -F ' ' ’{print $2}’ | awk ’NR==1’`USER=monitorPASSWORD=xxxxxxTIME=`date`WHEREIS_MYSQL=/opt/mysql/bin/mysqlWEBHOOK=’https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=bb09197b-5ff6-4928-9872-xxxxxx’wx(){cat > $0.msg << EOFcurl ’$WEBHOOK’ -H ’Content-Type: application/json’ -d ’ { 'msgtype': 'text', 'text': { 'content': '$1', } }’EOFsh $0.msg && rm -rf $0.msg}Check_Mysql_Slave(){ $WHEREIS_MYSQL -u$USER -p$PASSWORD -h$SLAVE_IP -e 'select version();' >/dev/null 2>&1 if [ $? -ne 0 ];then echo 'Mysql is stopped $DATE' >> /data/mysql/check.log ERROR='ERROR:Mysql-$SLAVE_IP cannot connectn$TIME' wx '$ERROR' else #echo '1' >> /data/mysql/check.log IO_SQL_STATUS=`$WHEREIS_MYSQL -u$USER -p$PASSWORD -h$SLAVE_IP -e 'show slave status G' 2>/dev/null | awk ’/Slave_.*_Running:/{print $1$2}’` for i in $IO_SQL_STATUS;do THREAD_STATUS_NAME=${i%:*} THREAD_STATUS=${i#*:} if [ '$THREAD_STATUS' != 'Yes' ];thenSTATUS='ERROR:Mysql-$SLAVE_IP $THREAD_STATUS_NAME status is $THREAD_STATUS!n$TIME' echo '$STATUS' >> /data/mysql/check.logwx '$STATUS' fi done fi}Check_Mysql_Slave
最終報(bào)警效果如下:
以上就是監(jiān)控MySQL主從狀態(tài)的shell腳本的詳細(xì)內(nèi)容,更多關(guān)于監(jiān)控MySQL主從狀態(tài)的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. 整理Oracle數(shù)據(jù)庫(kù)碎片2. 用腳本和查詢主動(dòng)監(jiān)視Oracle 9i性能3. MySQL慢查詢以及解決方案詳解4. Oracle 數(shù)據(jù)庫(kù)集中復(fù)制方法逐步精細(xì)5. SQL Server中的數(shù)據(jù)類(lèi)型詳解6. MySQL主備操作以及原理詳解7. Oracle?存儲(chǔ)過(guò)程詳細(xì)介紹使用實(shí)踐8. MySQL ibdata1文件減肥過(guò)程解析9. mysql-joins具體用法說(shuō)明10. MyBatis官方代碼生成工具給力(解放雙手)
