lvs健康检查脚本第三版
2017-08-30 20:37
344 查看
如下是学习完马哥视频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
#!/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
相关文章推荐
- lvs+keepalived自定义健康检查脚本(MISC_CHECK用法)
- LVS服务脚本及后端服务健康状态检查
- LVS之RealServer健康检查脚本
- lvs-dr启动及健康状态检查脚本
- LVS之五:使用脚本实现RealServer的健康检查
- lvs的realserver健康检查脚本
- LVS环境搭建及图形化管理(Pacemaker管理+heartbeat心跳+ipvs(DR)+ldirector健康检查及转发)
- lvs健康检测脚本
- LVS自动化添加及删除ipvsadm和后端服务器健康状态检测脚本
- 最近在学习LVS(Linux virtual Server)高可用,Keepalived用于健康检查
- LVS环境搭建及图形化管理(Pacemaker管理+heartbeat心跳+ipvs(DR)+ldirector健康检查及转发)
- oracle 数据库性能健康检查脚本[转帖]
- 如何编写LVS对Real Server的健康状态检测脚本
- MySQL服务健康检查脚本
- 服务器健康检查脚本
- 负载均衡的健康检查脚本应用 推荐
- SQL 性能健康检查脚本 (SQLHC) (Doc ID 1626277.1)
- lvs+keepalived健康检查
- 服务器健康状态检查脚本
- LVS模式的持久连接与健康状况检查