您好,登錄后才能下訂單哦!
MySQL主從復制狀態監控及微信告警
shell腳本實現當MySQL主從狀態異常時,觸發微信告警
1. 設置主從監控腳本
vi /opt/scripts/mysql/check_repl_status.sh
#!/bin/bash
host='' # Slave 機器
user='' # mysql 帳號(能執行show slave status即可,不需要太大的權限)
passwd='' # mysql 密碼
_msgBodys()
{
local int AppID=0
local UserID=$1
local Msg="$2"
cat << EOF
{
"touser": "${UserID}",
"msgtype": "text",
"agentid": "${AppID}",
"text": {
"content": "${Msg}"
},
"safe": "0"
}
EOF
}
_sendMsgs()
{
CropID='' #微信公眾號ID
Secret='' #微信公眾號Secret
GURL="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=${CropID}&corpsecret=${Secret}"
Gtoken=$(/usr/bin/curl -s -G $GURL | grep -Po "(?<=access_token\W{3})[\w-]+")
PURL="https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=${Gtoken}"
/usr/bin/curl -s -k --data-ascii "$(_msgBodys "$1" "$2")" $PURL
}
num=`/opt/mysql/bin/mysql -u$user -p$passwd -h$host -e 'show slave status\G' |grep -E "Slave_IO_Running:|Slave_SQL_Running:"|awk '{print $2}'|grep -c Yes`
#檢查主從是否存在
if [ ! $num ]
then
msgs="Conn lost with mysql"
logtime=`date "+%Y-%m-%d %H:%M:%S"`
send_msg="XXX MySql Slave連接狀態\n${msgs}\n檢查時間:${logtime}"
#發送給所有人
_sendMsgs "@all" "$send_msg"
#狀態不全為yes
elif [ $num -lt 2 ]
then
msgs=`/opt/mysql/bin/mysql -u$user -p$passwd -h$host -e 'show slave status\G' |grep -E "Master_Host:|Slave_IO_Running:|Slave_SQL_Running:"|sed s/[[:space:]]//g`
logtime=`date "+%Y-%m-%d %H:%M:%S"`
send_msg="XXX MySql主從復制狀態\n${msgs}\n檢查時間:${logtime}"
#發送給所有人
_sendMsgs "@all" "$send_msg"
fi
2. 設置crontab定時任務
*/5 * * * * /bin/bash /opt/scripts/mysql/check_repl_status.sh &>/dev/null 2>&1
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。