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

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

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

阶段3:请使用数组技术实现上述脚本(获取主从判断及错误号部分)[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    #和主库比同步延迟的秒数准备:

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秒实现检测一次。#!/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

终极版:#!/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

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主从同步状态是否异常,根据'_Running|Behind_Master|Last_SQL_Errno'

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

以下是一个监控MySQL主从同步状态是否异常的脚本示例: ```bash #!/bin/bash # 主库的IP和端口 MASTER_HOST="主库IP" MASTER_PORT="主库端口" # 从库的IP和端口 SLAVE_HOST="从库IP" SLAVE_PORT="从库端口" # 检查主从同步状态 function check_replication_status() { # 获取主库和从库的状态信息 MASTER_STATUS=$(mysql -h $MASTER_HOST -P $MASTER_PORT -e "SHOW MASTER STATUS\G") SLAVE_STATUS=$(mysql -h $SLAVE_HOST -P $SLAVE_PORT -e "SHOW SLAVE STATUS\G") # 检查同步状态是否正常 if [[ $MASTER_STATUS =~ "File:" && $SLAVE_STATUS =~ "Waiting for master to send event" ]]; then echo "Replication status: OK" else echo "Replication status: ERROR" echo "Master Status:" echo "$MASTER_STATUS" echo "Slave Status:" echo "$SLAVE_STATUS" # 在此处可以添加其他异常处理逻辑,比如发送邮件通知管理员等 fi } # 执行检查函数 check_replication_status ``` 在脚本中,你需要将 `主库IP`、`主库端口`、`从库IP` 和 `从库端口` 替换为实际的主从数据库的 IP 地址和端口号。 脚本会通过执行 `SHOW MASTER STATUS` 和 `SHOW SLAVE STATUS` 命令来获取主库和从库的状态信息。然后,它会检查主库的状态是否包含 "File:",以及从库的状态是否包含 "Waiting for master to send event",如果满足这两个条件,则认为主从同步状态正常。 如果同步状态异常,脚本会输出 "Replication status: ERROR",并显示主库和从库的状态信息。你可以在此处添加其他异常处理逻辑,根据实际需求进行处理,比如发送邮件通知管理员等。 你可以将该脚本设置为定时任务,定期执行来监控MySQL主从同步状态是否异常
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值