记一次Nginx+Keepalived高可用故障转移
Master端:192.168.2.156
! Configuration File for keepalived global_defs { notification_email { acassen@firewall.loc failover@firewall.loc sysadmin@firewall.loc } notification_email_from Alexandre.Cassen@firewall.loc smtp_server 192.168.2.156 smtp_connect_timeout 30 router_id LVS_DEVEL } vrrp_script check_nginx { script "/data/sh/check_nginx.sh" interval 2 weight 2 } vrrp_instance VI_1 { state BACKUP interface eth0 virtual_router_id 51 priority 100 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.2.100 } track_script { check_nginx } }
slave端:192.168.2.157
! Configuration File for keepalived global_defs { notification_email { acassen@firewall.loc failover@firewall.loc sysadmin@firewall.loc } notification_email_from Alexandre.Cassen@firewall.loc smtp_server 192.168.2.156 smtp_connect_timeout 30 router_id LVS_DEVEL } vrrp_script check_nginx { script "/data/sh/check_nginx.sh" interval 2 weight 2 } vrrp_instance VI_1 { state BACKUP interface eth0 mcast_src_ip 192.168.2.157 virtual_router_id 51 priority 90 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.2.100 } track_script { check_nginx } }
故障转移脚本
#vim /data/sh/check_nginx.sh
#!/bin/bash COUNT=$(ps -C nginx --no-header |wc -l) if [ "${COUNT}" = "0" ];then echo "重启nginx" sleep 2 COUNT=$(ps -C nginx --no-header |wc -l) if [ "${COUNT}" = "0" ];then systemctl stop keepalived fi fi
# chmod a+x /data/sh/check_nginx.sh
[root@localhost ~]# crontab -e
*/1 * * * * /data/sh/check_nginx.sh >> /var/log/check_nginx.log
测试:当我们尝试停止nghinx时,当手动停止nginx约2秒之后,此时会关闭keepalived,实现vip转移
浏览器访问浏览:VIP192.168.2.100即可
好了,到这里就结束了,喜欢我的博客作品,那就请关注我吧,如果对博客文章有更好的建议或者技术疑问欢迎在下方评论区留言,也可以在左侧找我的联系方式和QQ群进行交流互动,感谢大家的支持
PS:技术文章为原创作品,未经允许,请勿转载,如果转发分享,请标明出处