監(jiān)控MySQL主從狀態(tài)的shell腳本
分享一個Linux下,監(jiān)控MySQL主從狀態(tài)及配合企業(yè)微信機器人報警的Shell腳本
SLAVE_IP:為監(jiān)控的主機IP USER:為msyql用戶 PASSWORD:為mysql密碼 WHEREIS_MYSQL:為mysql命令路徑 WEBHOOK:為企業(yè)微信機器人Webhook地址 wx():為企業(yè)微信機器人函數(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
最終報警效果如下:

以上就是監(jiān)控MySQL主從狀態(tài)的shell腳本的詳細內(nèi)容,更多關(guān)于監(jiān)控MySQL主從狀態(tài)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. ubuntu下使用SQLite3的基本命令2. MYSQL技巧:為現(xiàn)有字段添加自增屬性3. MYSQL(電話號碼,身份證)數(shù)據(jù)脫敏的實現(xiàn)4. Mysql入門系列:MYSQL圖像數(shù)據(jù)的處理5. MySQL存儲過程例子(包含事務(wù)、參數(shù)、嵌套調(diào)用、游標循環(huán)等)6. 一些很有用的SQLite命令總結(jié)7. Oracle存儲過程與函數(shù)的詳細使用教程8. Mysql入門系列:MYSQL創(chuàng)建、刪除和選擇數(shù)據(jù)庫9. SQL Server中搜索特定的對象10. sql server刪除數(shù)據(jù)庫文件的方法

網(wǎng)公網(wǎng)安備