脚本编写思路:

(1)根据show slave statusG;l列Seconds_Behind_Master;

(2)Seconds_Behind_Master= NULL判断io或sql进程哪个停止或者二者都停止

(3)Seconds_Behind_Master= 0复制正常

(4)Seconds_Behind_Master>0 说明主从延迟

上述(2)、(4)会发出邮件报警,正常时忽略,脚本10s采集数据一次。

#!/bin/bash

########################################

# automatic check mysql replacation status from salve database #

# edit by rgf in 2014/09/03                                                  #

# The scropt distributes in slave databases,if slave db faults,      #

# then it will send email to administrator or dba                       #

########################################

export LANG=zh_CN

base_dir=/usr/bin

logs_dir=/opt/mysql/log

db_user=root

db_pwd=123456

EmailFile=$logs_dir/${HOSTNAME}_mail_`date +%Y%m%d`.log

Email=gfsunny@163.com

while true

do

echo "       " > $EmailFile

echo "-----------------------" >> $EmailFile

echo "`date +"%y-%m-%d %H:%M:%S"`" >> $EmailFile

echo "-------------------------" >> $EmailFile

Port=`netstat -ntlp|grep mysqld | awk -F ' ' '{print $4}' | awk -F ':' '{print $2}'`

Ip=`ifconfig |grep "inet addr:"|grep -v "inet addr:127.0.0.1" | awk -F ' ' '{print $2}' | awk -F ':' '{print $2}'`

echo "${HOSTNAME}:$Ip:$Port" >> $EmailFile

        Seconds_Behind_Master=`${base_dir}/mysql  -u$db_user -p$db_pwd -e "show slave statusG;" | grep "Seconds_Behind_Master:" | awk -F ':' '{print $2}'` &> /dev/null

        Slave_IO_Running=`${base_dir}/mysql  -u$db_user -p$db_pwd -e "show slave statusG;" | grep "Slave_IO_Running:" | awk -F ':' '{print $2}'` &> /dev/null

        Slave_SQL_Running=`${base_dir}/mysql  -u$db_user -p$db_pwd -e "show slave statusG;" | grep "Slave_SQL_Running:" | awk -F ':' '{print $2}'` &> /dev/null

        if [ $Seconds_Behind_Master = "NULL" ];then

                echo "Disruption of replication" >> $EmailFile

                if [ $Slave_IO_Running = "Yes" -a $Slave_SQL_Running = "No" ];then

                        echo "Slave_IO_Running is OK and Slave_SQL_Running is failure" >> $EmailFile

                        mail -s "Slave_IO OK AND Slave_SQL failured!!" $Email < $EmailFile

                elif [ $Slave_IO_Running = "No" -a $Slave_SQL_Running = "Yes" ];then

                        echo "Slave_IO_Running is failure and Slave_SQL_Running is OK" >> $EmailFile

                        mail -s "Slave_IO failured AND Slave_SQL OK!!" $Email < $EmailFile

                else

                        echo "Slave_IO_Running is failure and Slave_SQL_Running is failure" >> $EmailFile

                        mail -s "Slave_IO failure AND Slave_SQL failure!!" $Email < $EmailFile

                fi

        elif [ $Seconds_Behind_Master -eq 0 ];then

                echo "slave is ok!" &> /dev/null

        elif [ $Seconds_Behind_Master -gt 0 ];then

                echo "slave has beened delayed compared with master" >> $EmailFile

                mail -s "slave has beened delayed" $Email < $EmailFile

        else

                echo "slave Unknown fault!" >> $EmailFile

                mail -s "slave Unknown fault!!" $Email < $EmailFile

        fi

sleep 10

done