You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 2 Next »

В окружении, в котором оба ваших основных сервера WNAM не могут общаться посредством multicast-пакетов (например, когда multicast не включен на распределенном коммутаторе VMware, или в среде OpenStack), вы можете использовать демон keepalived в unicast-режиме.

Установите необходимый пакет:

apt install keepalived

Создайте конфигурационный файл /etc/keepalived/keepalived.conf:

На первом сервере

vrrp_script check_wnam {
script "/home/wnam/check_wnam.sh"
interval 10
fall 2
rise 2
}
vrrp_instance wnam_instance {
interface eth0
track_interface {
eth0
}
state MASTER
virtual_router_id 50
priority 100
preempt
unicast_src_ip 1.2.3.89
unicast_peer {
1.2.3.90
}
virtual_ipaddress { 
1.2.3.91 dev eth0
}
track_script {
check_wnam
}
notify /home/wnam/keepalived.state.sh
}


На втором сервере:

vrrp_script check_wnam {
 script "/home/wnam/check_wnam.sh"
interval 10
fall 2
rise 2
}
vrrp_instance wnam_instance {
interface eth0
track_interface {
eth0
}
state BACKUP
virtual_router_id 50
priority 50
preempt
unicast_src_ip 1.2.3.90
unicast_peer {
1.2.3.89
}
virtual_ipaddress {
1.2.3.91 dev eth0
}
track_script {
check_wnam
}
notify /home/wnam/keepalived.state.sh 
}

На каждом из двух серверов создайте одинаковые скрипты:

/home/wnam/check_wnam.sh 

#!/bin/bash
# Check if WNAM is running, return 1 if not.
# Used by keepalived to initiate a failover in case WNAM is down
WNAM_STATUS=$(/bin/ps ax | grep -w wnam.war | grep -w java)
if [ "$WNAM_STATUS" != "" ]
then
exit 0
else
logger "WNAM is NOT running. Setting keepalived state to FAULT."
exit 1
fi


/home/wnam/keepalived.state.sh

#!/bin/bash
TYPE=$1
NAME=$2
STATE=$3
echo $STATE > /var/run/keepalived.state

Дайте скриптам права "на исполнение":

chmod +x /home/wnam/keepalived.state.sh /home/wnam/check_wnam.sh 

Включите, и перезапустите сервис keepalived на обоих серверах:

systemctl enable keepalived.service 
systemctl restart keepalived.service

После этого первый сервер получит кластерный IP адрес, а в логе (/var/log/syslog) будут записи вида:

May 8 16:37:55 r-sr-wnam-app-001 Keepalived_vrrp[16978]: VRRP_Script(check_wnam) succeeded
May 8 16:37:55 r-sr-wnam-app-001 Keepalived_vrrp[16978]: (wnam_instance) Entering BACKUP STATE
May 8 16:37:59 r-sr-wnam-app-001 systemd[1]: Reloading.
May 8 16:37:59 r-sr-wnam-app-001 Keepalived_vrrp[16978]: (wnam_instance) Entering MASTER STATE


  • No labels