实现LVS后端服务健康状态检查

#!/bin/bash

#

VIP=172.169.18.150

CPOPT=80   #集群端口

FALI_BACK=127.0.0.1   #备用

RS=("172.169.18.240" "172.169.18.232")  #集群主机

declare -a RSSTATUS

#RSTATUS=("1" "1")  #状态码

RW=("2" "1")   #权重

RPORT=80  #RIP端口

TYPE=g

CHKLOOP=3  #检查次数

LOG=/var/log/ipvsadmlog.log

addrs() {

ipvsadm -a -t $VIP:$CPOPT -r $1:$RPORT -$TYPE -w $2

[ $? -eq 0 ] && return 0 || return 1

}

delrs() {

ipvsadm -d -t $VIP:$CPOPT -r $1:$RPORT

[ $? -eq 0 ] && return 0 || return 1

}

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

}

inststatus() {

local I

local COUNT=0;

for I in ${RS[*]}; do

#if checkrs $I; then

if ipvsadm -L -n | grep "$I:$RPORT" && > /dev/null; then

RSSTATUS[$COUNT]=1

else

RSSTATUS[$COUNT]=0

fi

let COUNT++

done

}

inststatus

while :; do

let COUNT=0

for I in ${RS[*]}; do

if checkrs $I; then

if [ ${RSSTATUS[$COUNT]} -eq 0 ]; then

addrs $I ${RW[$COUNT]}

[ $? -eq 0 ] && RSSTATUS[$COUNT]=1 && echo "`date +'%F %H:%M:%S'`,$I is back." >> $LOG

fi

else

if [ ${RSSTATUS[$COUNT]} -eq 1 ]; then

delrs $I

[ $? -eq 0 ] && RSSTATUS[$COUNT]=0 && echo "`date +'%F %H:%M:%S'`,$I is gone." >> $LOG

fi

fi

let COUNT++

done

sleep 10

done

#检查测试服务

# bash -x ipvsadm.sh

猜你喜欢

转载自blog.51cto.com/13941177/2327375