Eu tenho o seguinte arquivo keepalived.conf:
vrrp_script chk_nginx {
script "curl http://localhost/vrrp_healthcheck/"
interval 2 # every 2 seconds
weight 2 # add 2 points if OK
}
vrrp_instance VI_1 {
interface ens160 # interface to monitor
virtual_router_id 50
priority 100
virtual_ipaddress {
192.168.120.25 label ens160:10
}
track_script {
chk_nginx
}
notify /usr/local/bin/notify.sh
}
No nó mestre, vejo o seguinte na saída do ifconfig:
ens160: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.120.20 netmask 255.255.255.224 broadcast 192.168.120.31
ether 00:50:56:a5:c5:3a txqueuelen 1000 (Ethernet)
RX packets 138308 bytes 130425415 (124.3 MiB)
RX errors 0 dropped 73 overruns 0 frame 0
TX packets 122917 bytes 50788591 (48.4 MiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
ens160:10: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 192.168.120.25 netmask 255.255.255.255 broadcast 0.0.0.0
ether 00:50:56:a5:c5:3a txqueuelen 1000 (Ethernet)
lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536
inet 127.0.0.1 netmask 255.0.0.0
loop txqueuelen 1 (Local Loopback)
RX packets 9730 bytes 812897 (793.8 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 9730 bytes 812897 (793.8 KiB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
O que me preocupa é o endereço de broadcast e de rede diferente na entrada ens160:10 (que é a criada pelo keepalived).
Eles não deveriam corresponder aos da interface normal?
No momento, minha configuração parece funcionar, mas quero ter certeza de que está configurada corretamente.
Você pode simplesmente modificar o bloco de endereços IP virtuais para ler:
A máscara padrão é
/32
ou255.255.255.255
.