實現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

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