keepalived处理高可用问题

本文介绍如何通过配置两个Nginx服务器并结合Keepalived实现高可用负载均衡方案,包括主备节点的搭建步骤及故障转移机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值