#======================================================================================= ## 检查MySQL是否已经运行 if [[ `ps aux | grep mysql[d] | wc -l` -eq 0 ]]; then echo The MySQL is not running at: `date +%F" "%H-%M-%S` >> ${LOGFILE} exit 1 fi
## 测试Slave端的连通性 nohup mysqladmin -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} ping > ${PINGFILE} retval=`grep "^error" ${PINGFILE}` rm -f ${PINGFILE} if [[ "${retval}X" != "X" ]]; then echo The MySQL Slave can not be connected at: `date +%F" "%H-%M-%S` >> ${LOGFILE} exit 1 fi
## 检查是否合法的Slave MASTER_ADDR=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}G;" | awk "$1=="Master_Host:" {print $2}"` LOCAL_ADDR=`/sbin/ifconfig eth1 | awk -F ":" "/inet addr/{print $2}" | sed "s/[a-zA-Z ]//g"` if [[ "${MASTER_ADDR}" != "${LOCAL_ADDR}" ]]; then echo The MySQL Slave is not lawful at: `date +%F" "%H-%M-%S` >> ${LOGFILE} exit 1 fi
## 获得Slave端信息,以此来确定是否处于正常同步的情况 IO_STATUS=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}G;" | awk "$1=="Slave_IO_Running:" {print $2}"` SQL_STATUS=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}G;" | awk "$1=="Slave_SQL_Running:" {print $2}"` if [[ "${IO_STATUS}" != "Yes" || "${SQL_STATUS}" != "Yes" ]]; then echo The MySQL Replication is not synchronous at: `date +%F" "%H-%M-%S` >> ${LOGFILE} exit 1 fi
## 再做一次判断,以保证数据同步绝对正常【创建测试数据】 mysql -uroot -e "create database if not exists mytestdb;" sleep 3
retval=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "show databases;" | grep mytestdb` mysql -uroot -e "drop database if exists mytestdb;" if [[ "${retval}X" = "X" ]]; then echo The MySQL Replication is not synchronous at: `date +%F" "%H-%M-%S` >> ${LOGFILE} exit 1 fi