且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

监控mysql主从同步状态是否异常,如果异常,则发生短信或邮寄给管理员

更新时间:2022-03-13 23:02:16

阶段1:开发一个守护进程脚本每30秒实现检测一次。

阶段2:如果同步出现如下错误号(1158,1159,1008,1007,1062),请跳过错误

阶段3:请使用数组技术实现上述脚本(获取主从判断及错误号部分)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[root@slave ~]# mysql -u root -proot -e "show slave status\G;"
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 172.16.1.2      #当前的mysql master服务器主机
                  Master_User: myslave
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-bin.000003
          Read_Master_Log_Pos: 471
               Relay_Log_File: relay-log-bin.000002
                Relay_Log_Pos: 252
        Relay_Master_Log_File: master-bin.000003
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
                     Master_SSL_Key: 
                           Seconds_Behind_Master: 0    #和主库比同步延迟的秒数
1
2
3
4
5
6
7
8
9
10
11
 准备:
  
 egrep "_Running|Behind_Master" slave.log   #过滤
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
        Seconds_Behind_Master: 0
         
 [root@slave ~]# egrep "_Running|Behind_Master" slave.log | awk '{print $NF}'
Yes
Yes
0


阶段一:开发一个守护进程脚本每30秒实现检测一次。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#!/bin/bash
while true
do
  array=($(egrep "_Running|Behind_Master" slave.log|awk '{print $NF}'))
  if "${array[0]}" == "Yes" -a "${array[1]}" == "Yes" -a "${array[2]}" == "0" ]
  then
    echo "MySQL is slave is ok"
  else
      char="MySQL slave is not ok"
      echo "$char"
      echo "$char"|mail -s "$char" 995345781@qq.com
      break
  fi
  sleep 30
done
 
 
执行结果:
[root@slave ~]# sh test.sh  
MySQL is slave is ok
MySQL is slave is ok


终极版:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#!/bin/bash
#Date:2017-7-3
#Author:xcn(baishuchao@yeah.net)
#version 1.0
mysql_cmd="mysql -u root -proot"
errorno=(1158 1159 1008 1007 1062)
while true
do
  array=($($mysql_cmd -e "show slave status\G"|egrep '_Running|Behind_Master|Last_SQL_Errno'|awk '{print $NF}'))
  if "${array[0]}" == "Yes" -a "${array[1]}" == "Yes" -a "${array[2]}" == "0" ]
  then
    echo "MySQL is slave is ok"
  else
      for ((i=0;i<${#errorno[*]};i++))
      do
        if "${array[3]}" "${errorno[$i]}" ];then
        $mysql_cmd -e "stop slave &&set global sql_slave_skip_counter=1;start slave;"
        fi
      done
      char="MySQL slave is not ok"
      echo "$char"
      echo "$char"|mail -s "$char" 995345781@qq.com
      break
  fi
  sleep 30
done


提示:这个脚本可以用于生产环境中,监控mysql主从同步状态是否异常,根据

1
'_Running|Behind_Master|Last_SQL_Errno'

这个进行判断,如果不正常的话则会进一步判断状态码,然后进行输出,则会发邮件或短信给运维人员





本文转自 baishuchao 51CTO博客,原文链接:http://blog.51cto.com/baishuchao/1944170