如下是学习完马哥视频lvs后改写的健康检查脚本第三版。利用工作之余三四个小时时间才把整个逻辑搞清楚,有时候自己都有点蒙圈,尤其是在写到while循环的时候。总的来说非常感谢马哥的慷慨解囊!脚本原稿及思路均来自马哥,自己又折腾几小时终于完成第三版!如有不妥之处,欢迎指出批评。
#!/bin/bash
#
VIP=192.168.28.50
CPORT=80
FAIL_BACK=127.0.0.1
RS=("192.168.28.11" "192.168.28.12")
#RSTATUS=("1" "1")
RW=("2" "1")
RPORT=80
TYPE=g
CHKLOOP=3
LOG=/var/log/ipvschk.log
#添加RS,添加成功返回0,否则返回1
function addrs() {
ipvsadm -a -t $VIP:$CPORT -r $1:$RPORT -$TYPE -w $2
[ $? -eq 0 ] && return 0 || return 1
}
#删除RS,删除成功返回0,否则返回1
function delrs() {
ipvsadm -d -t $VIP:$CPORT -r $1:$RPORT
[ $? -eq 0 ] && return 0 || return 1
}
#检测RS服务是否在线,注意一下这里面指的RS的服务,如果连续三次都监测不通,则返回1,否则返回0
function checkrs(){
local I=1
while [ $I -le $CHKLOOP ];do
if curl --connect-timeout 1 http://$1 &>/dev/null ; then
return 0
fi
let I++
done
return 1
}
#初始化RS在线状态,如果在线,设置节点初始化状态为1,否则为0
function initstatus(){
local I
local COUNT=0
for I in ${RS[*]};do
if checkrs $I ; then
RSSTATUS[${COUNT}]=1
else
RSSTATUS[${COUNT}]=0
fi
let COUNT++
done
}
#ipvs状态检查,如果已添加至ipvs则返回0,否则返回1
function rrstatus(){
realsta=`ipvsadm -L -n | grep $1 | grep -v grep | wc -l`
[ $realsta -ne 0 ] && return 0 || return 1
}
#进行初始化
initstatus
#判断ipvsadm是否启动,如果没有启动则直接退出,否则继续
if [ ! -e /var/lock/subsys/ipvsadm ]; then
echo "`date +'%F %H:%M:%S'`, ipvs is stop." >> $LOG
exit 1
fi
#在这里逻辑关系有点复杂,总体思路是:监测rs是否加入到ipvs中。如果未添加并且在线则添加;如果已添加并且不在线,则删除
while :; do
let COUNT=0
for I in ${RS[*]} ; do
rrstatus $I
[ $? -eq 0 ] && RRSTATUS=1 || RRSTATUS=0
if checkrs $I; then
if [ $RRSTATUS -eq 0 ]; then
addrs $I ${RW[$COUNT]}
if [ $? -eq 0 ] ; then
RSSTATUS[$COUNT]=1
echo "`date +'%F %H:%M:%S'`, $I is back." >> $LOG
else
echo "`date +'%F %H:%M:%S'`, add $I faild." >> $LOG
fi
fi
else
if [ $RRSTATUS -eq 1 ] ; then
delrs $I
if [ $? -eq 0 ] ; then
RSSTATUS[$COUNT]=0
echo "`date +'%F %H:%M:%S'`, $I is gone." >> $LOG
else
echo "`date +'%F %H:%M:%S'`, del $I faild or $I already has gone." >> $LOG
fi
fi
fi
let COUNT++
done
#如果服务都不在线,并且备用服务未添加至ipvs,则添加备用服务;一旦有服务在线,则删除已添加的备用节点
if [ ${RSSTATUS[0]} -eq 0 -a ${RSSTATUS[1]} -eq 0 ];then
rrstatus $FAIL_BACK
if [ $? -eq 1 ]; then
ipvsadm -a -t $VIP:$CPORT -r $FAIL_BACK -w 1
fi
else
rrstatus $FAIL_BACK
if [ $? -eq 0 ]; then
ipvsadm -d -t $VIP:$CPORT -r $FAIL_BACK
fi
fi
#5s监测一次
sleep 5
done