keepalived处理高可用问题

tomcat挂掉nginx可以分发到别的tomcat,nginx要是挂掉,就需要处理高可用问题了
1.构建两个提供一样并发服务的nginx,并启动
scp -r tengine.2.0 root@node2:/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

猜你喜欢

转载自blog.csdn.net/u011418530/article/details/80276312