文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mysql主从状态监控脚本

2024-04-02 19:55

关注

目标:对Mysql从库进行状态监控,如果从库复制异常就告警

思路:

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


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯