CentOS下编写shell脚本来监控MySQL主从复制

目的:定时监控MySQL主从数据库是否同步,如果不同步,记录故障时间,并执行命令使主从恢复同步状态

1、创建脚本文件

#!/bin/sh
# check_mysql_slave status
#
ip=eth0  #网卡名称
mysql_binfile=/wxccpf/service/mysql/bin/mysql
mysql_user=root  #MySQL数据库账号
mysql_pass=123456  #密码
mysql_sockfile=/tmp/mysql.sock
datetime=`date +"%Y-%m-%d/%H:%M:%S"`   #获取当前时间
mysql_slave_logfile=/wxccpf/log/mysql/check_mysql_slave.log   #日志文件路径,必须提前创建好
slave_ip=`ifconfig $ip|grep "inet addr" | awk -F[:" "]+ '{print $4}'`
status=$($mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "show slave status\G" | grep -i "running")
Slave_IO_Running=`echo $status | grep Slave_IO_Running | awk ' {print $2}'`
Slave_SQL_Running=`echo $status | grep Slave_SQL_Running | awk '{print $2}'`
if [ "$Slave_IO_Running" = "Yes" -a "$Slave_SQL_Running" = "Yes" ]
then
    echo "Slave is Running!"
else
    echo " $datetime $slave_ip Slave is not running!" >> $mysql_slave_logfile
    $mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "SLAVE STOP;"
    $mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;"
    $mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "SLAVE START;"
    $mysql_binfile -u$mysql_user -p$mysql_pass -S $mysql_sockfile -e "EXIT"
fi
:wq! #保存退出

chmod +x /home/crontab/check_mysql_slave.sh #添加脚本执行权限


2、添加任务计划,修改/etc/crontab

vi /etc/crontab #在最后一行添加
*/10 * * * * root /home/crontab/check_mysql_slave.sh #表示每10分钟执行一次
:wq! #保存退出


3、重新启动crond使设置生效

service crond reload #启动

可以根据日志文件/wxccpf/log/mysql/check_mysql_slave.log查看MySQL主从同步状态


你可能感兴趣的:(mysql,主从复制)