redis-backup.sh
#!/bin/bash
LOGFILE="/etc/keepalived/log/keepalived-redis-stat.log"
echo "[backup]" >> $LOGFILE
date >> $LOGFILE
echo "Being slave ..." >> $LOGFILE 2>&1
sleep 15
echo "Run SLAVEOF cmd..." >> $LOGFILE
redis-cli SLAVEOF 192.168.0.150 6379 >> $LOGFILE 2>&1
如果master 为 151 那么
“redis-cli SLAVEOF 192.168.0.150 6379 >> $LOGFILE 2>&1”
如果slave ip为 150 那么
”redis-cli SLAVEOF 192.168.0.151 6379 >> $LOGFILE 2>&1“
redis_check.sh
#!/bin/bash
ALIVE=`redis-cli PING`
if [ "$ALIVE" == "PONG" ]; then
echo $ALIVE
exit 0
else
echo $ALIVE
exit 1
fi
redis_master.sh
#!/bin/bash
LOGFILE="/etc/keepalived/log/keepalived-redis-stat.log"
echo "[master]" >> $LOGFILE
date >> $LOGFILE
echo "Being master ...." >> $LOGFILE 2>&1
echo "Run SLAVEOF cmd ..." >> $LOGFILE
redis-cli SLAVEOF 192.168.0.151 6379 >> $LOGFILE 2>&1
sleep 10
echo "Run SLAVEOF NO ONE cmd..." >> $LOGFILE
redis-cli SLAVEOF NO ONE >> $LOGFILE 2>&1
keepalived.conf
vrrp_script chk_redis {
script "/etc/keepalived/scripts/redis_check.sh" ###监控脚本
interval 2 ###监控时间
}
vrrp_instance VI_1 {
state MASTER ###设置为MASTER
interface eth0 ###监控网卡
virtual_router_id 52
priority 101 ###权重值
authentication {
auth_type PASS ###加密
auth_pass redis ###密码
}
track_script {
chk_redis ###执行上面定义的chk_redis
}
virtual_ipaddress {
192.168.0.149 ###VIP
}
notify_master /home/lhb/sh/redis_master.sh
notify_backup /home/lhb/sh/redis_backup.sh
}
存放目录结构 /etc/keepalived/keepalived.conf
/etc/keepalived/log/keepalived-redis-stat.log
/etc/keepalived/scirpts/redis_check.sh
/etc/keepalived/scirpts/redis_master.sh
/etc/keepalived/scirpts/redis_backup.sh
需要安装文件:
apt-get install redis
apt-get
install
libssl-dev
apt-get
install
openssl
apt-get
install
libpopt-dev
apt-get
install
keepalived
执行 keepalived -f /etc/keepalived/keepalived.conf