目标:对Mysql从库进行状态监控,如果从库复制异常就告警
10年积累的成都做网站、成都网站设计、成都外贸网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有大东免费网站建设让你可以放心的选择与我们合作。思路:
1、首先查找Mysql从库的4个参数值(show slave status根据这个命令);分别是从库的IO线程、SQL线程、复制延迟时间(这个在以下脚本没用到,可以再写个脚本对其延迟进行告警)、错误码
2、函数Mysql_status判断,对IO线程、SQL线程、错误码三者逻辑与判断
3、如果为假则执行函数Mysql_Errno
4、对于mysql错误码为1158 1159 1008 1007 1062 我们可以进行停止slave,跳过当前复制条数,进行下一条复制
[root@zabbix script]# cat mysql_check.sh
#!/bin/bash
#
#2017.5.8
#mysql状态监测告警
. /etc/init.d/functions
Mysql_IO_cmd=`mysql -h 10.222.1.5 -uroot -p123456 -e 'show slave status\G'|grep Slave_IO_Running |awk '{print $NF}'`
Mysql_SQL_cmd=`mysql -h 10.222.1.5 -uroot -p123456 -e 'show slave status\G'|grep Slave_SQL_Running |awk '{print $NF}'`
Mysql_Be_cmd=`mysql -h 10.222.1.5 -uroot -p123456 -e 'show slave status\G'|grep Seconds_Behind_Master |awk '{print $NF}'`
Mysql_Errno_cmd=`mysql -h 10.222.1.5 -uroot -p123456 -e 'show slave status\G'|grep Last_SQL_Errno |awk '{print $NF}'`
ErrorNo=(1158 1159 1008 1007 1062)
##判断mysql复制的错误码
Mysql_Errno() {
for sum in $ErrorNo
do
if [ "$Mysql_Errno_cmd" == "$sum" ];then
echo "$(date +%F_%R)错误状态码:$Mysql_Errno_cmd" >> /tmp/mysql_error.log
mysql -h 10.222.1.5 -uroot -p123456 -e 'stop slave;set global sql_slave_skip_counter=1;start slave;'
echo `sort -r /tmp/mysql_error.log` |mail -s "MySQL Slave is error" zabbix_client@jt56.org
else
echo "$(date +%F_%R)错误状态码:$Mysql_Errno_cmd" >> /tmp/mysql_error.log
#echo `sort -r /tmp/mysql_error.log` |mail -s "MySQL Slave is error" zabbix_client@jt56.org
uniq /tmp/mysql_error.log |mail -s "MySQL Slave is error" zabbix_client@jt56.org
fi
done
}
##监测mysql状态函数
Mysql_status() {
if [ "$Mysql_IO_cmd" == "Yes" -a "$Mysql_SQL_cmd" == "Yes" -a "$Mysql_Errno_cmd" == "0" ];then
echo
action "mysql status" /bin/true
else
echo
action "mysql status" /bin/false
Mysql_Errno
fi
}
Mysql_status
另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。