Nginx + Keepalived 双机热备

本文详细介绍了如何使用Nginx和Keepalived构建双机热备系统,通过设置虚拟IP实现负载均衡及故障自动切换,确保服务的高可用性和稳定性。

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

基于Nginx和Keepalived双机热备

Keepalived 实现双机热备,消除一台机器单点故障的发生。准备2台机器ip地址分别为192.168.163.34、192.168.163.35。同时这2台机器都设置同一虚拟ip,
这里虚拟ip设置为192.168.163.100。2台机器都需要装上nginx和keepalived。

设置虚拟ip

这里要用到虚拟ip,虚拟ip的设置参考

安装nginx 并启动

nginx安装

#####192.168.163.34启动

192.168.163.35启动

安装Keepalived
tar –zxvf keepalived-1.2.19.tar.gz
cd keepalived-1.2.19
./configure --prefix=/usr/local/keepalived
make
make install
keepalived.conf配置(192.168.163.34)
! 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.200.1
   smtp_connect_timeout 30
   router_id LVS_DEVELA #MASTER节点
}

vrrp_instance VI_1 {
    state MASTER
    interface eth1
    virtual_router_id 51 #主、备必须一样  
    priority 100 #优先级
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.163.100 #VRRP HA虚拟地址
    }
}
keepalived.conf配置(192.168.163.35)
! 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.200.1
   smtp_connect_timeout 30
   router_id LVS_DEVELB #BACKUP节点
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth1
    virtual_router_id 51 #主、备必须一样  
    priority 99#优先级
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.163.100 #VRRP HA虚拟地址
    }
}

建立软链接并启动keepalived
ln -s /usr/local/keepalived/sbin/keepalived /sbin/
ln -s /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/
ln -s /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
keepalived -D -f /usr/local/keepalived/etc/keepalived/keepalived.conf

测试

测试可见,浏览器中我们通过虚拟ip来访问,如上面所设置的会访问到master 34的机器。34这台机器的优先级高于35。

停用master机器

master机器停用(宕机、nginx死机等)会看到自动切换到35 backup那台机器。即192.168.163.34那台机器访问不了。

参考

nginx-ha-keepalived
keepalived

### 配置NginxKeepalived实现双机热备 为了确保Web服务的高可用性和稳定性,可以采用NginxKeepalived相结合的方式构建双机热备架构。此方法能够有效预防因单一节点故障而导致的服务中断。 #### 架构概述 请求流量首先进入由Keepalived管理的虚拟IP(VIP),而非直接到达Nginx实例。Keepalived负责监测后端Nginx的状态,并依据预设策略调整VIP归属,以此达成自动化的故障转移机制[^1]。 #### 主要组件配置 - **Master Server**: 负责处理正常情况下的全部请求。 - **Backup Server(s)**: 当主服务器不可用时接管工作负载。 对于每台运行Nginx的服务器而言,其`/usr/local/nginx/conf/nginx.conf`中的HTTP部分需保持一致设置,以便于统一管理和维护[^2]。 #### Keepalived配置要点 在两台服务器上均应编写并部署用于检测Nginx健康状况的Shell脚本,例如: ```bash #!/bin/bash A=$(ps -C nginx --no-header | wc -l) if [ "$A" -eq 0 ]; then systemctl start nginx sleep 2 if [ $(ps -C nginx --no-header | wc -l) -eq 0 ]; then killall keepalived fi fi ``` 上述脚本会周期性检查Nginx进程是否存在;一旦发现异常即尝试重新启动之;倘若连续两次重启失败,则终止本地Keepalived进程以触发VIP迁移至备用节点[^4]。 #### 关键注意事项 - 确认所有涉及路径和服务名称准确无误; - 测试阶段务必验证各环节逻辑顺畅运作; - 生产环境中实施前充分评估潜在风险并制定应急预案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值