監(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)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Mysql入門系列:在MYSQL結(jié)果集上執(zhí)行計(jì)算2. Microsoft Office Access備份表的方法3. Oracle災(zāi)難防護(hù)的關(guān)鍵技術(shù)4. SQLite3 API 編程手冊5. Microsoft Office Access刪除字段的方法6. SQL SERVER的ROWCOUNT關(guān)鍵字7. CentOS安裝和設(shè)置MariaDB的教程8. MySQL雙主(主主)架構(gòu)配置方案9. MySql分組后隨機(jī)獲取每組一條數(shù)據(jù)的操作10. Microsoft Office Access重新編號的方法
