MySQL主从复制状态监控及微信告警
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL主从复制状态监控及微信告警,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1583字,纯文字阅读大概需要3分钟。
内容图文
![MySQL主从复制状态监控及微信告警](/upload/InfoBanner/zyjiaocheng/914/e92e42d5f4fd46c693f12d02f7471d90.jpg)
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
内容总结
以上是互联网集市为您收集整理的MySQL主从复制状态监控及微信告警全部内容,希望文章能够帮你解决MySQL主从复制状态监控及微信告警所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。