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主從同步狀態


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章