天天看点

keepalived处理高可用问题

tomcat挂掉nginx可以分发到别的tomcat,nginx要是挂掉,就需要处理高可用问题了 1.构建两个提供一样并发服务的nginx,并启动 scp -r tengine.2.0 [email protected]:/opt/local/soft/ 复制tengine.2.0到node2服务器下 `pwd`是获取相同路径 # 注意tengine就是Nginx 2.在两个节点分别安装keepalived yum -y install keepalived 3.主节点修改keepalived的配置 vi /etc/keepalived/keepalived.conf vrrp_instance VI_1 { state MASTER #主机 interface eth0 virtual_router_id 51 priority 100 #主机权重 advert_int 1 authentication { auth_type PASS auth_pass 1111 }

virtual_ipaddress { #主副机虚拟IP要设置一样 192.168.57.200 dev eth0 label eth0:tvip } } 4.备节点修改keepalived.conf文件 vrrp_instance VI_1 { state BACKUP #副机 interface eth0 virtual_router_id 51 priority 98 #副机权重 advert_int 1 authentication { auth_type PASS auth_pass 1111 }

virtual_ipaddress { #设置虚拟IP 192.168.57.200 dev eth0 label eth0:tvip } }

5.分别重启keepalived (service keepalived start ) 关掉主节点发现备节点继承虚拟ip192.168.57.200 继续提供服务

这里有个问题是只适用于主节点宕机了,如果只是nginx进程挂了是不起作用的

写个脚本探测nginx进程,如果进程没有了,关掉keepalived程序来进行主备切换

这里主从节点一样配置就是修改下state和priority

vrrp_script check_nginx { script "/root/nginx.sh" ##监控脚本 interval 2 ##时间间隔,2秒 weight 2 ##权重 }

vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 51 priority 100 advert_int 1 authentication { auth_type PASS auth_pass 1111 } track_script { check_nginx #监控脚本 }

virtual_ipaddress { 192.168.57.200 dev eth0 label eth0:tvip } }

脚本如下:cd /root vim nginx.sh 主从服务器都添加 #!/bin/bash # 如果进程中没有nginx则将keepalived进程kill掉 A=`ps -C nginx --no-header |wc -l` ## 查看是否有 nginx进程 把值赋给变量A if [ $A -eq 0 ];then ## 如果没有进程值得为 零 service keepalived stop ## 则结束 keepalived 进程 fi

注意修改脚本文件的可执行权限chmod 755 nginx.sh

继续阅读