打造零故障架构:基于 Keepalived 的 Nginx / HAProxy 高可用实战指南
在上一篇文章中,我们介绍了 Nginx 的典型安装方法与支持 HTTP、HTTPS、WebSocket、TCP 等协议的反向代理配置实践。作为互联网服务中的核心入口,Nginx 和 HAProxy 的可用性直接关系到整体业务的稳定性。因此,在本篇文章中,我们将探讨如何使用 Keepalived 实现 Nginx 和 HAProxy 的高可用架构设计,确保服务在节点故障时自动切换,保障访问不中断。
一、为什么需要高可用?
在单节点部署中,一旦代理服务器宕机,整个网站或服务就会不可用。引入 Keepalived 后,可以通过虚拟 IP(VIP)绑定多个节点,在主节点失效时自动切换到备用节点,保障业务连续性。
二、Keepalived 实现原理
Keepalived 本质是一个实现 VRRP(Virtual Router Redundancy Protocol)协议的服务,通过抢占机制决定哪个节点拥有 VIP。当主节点失效,备用节点通过检测条件接管 VIP,从而实现“故障转移”。
其关键机制包括:
- VIP 漂移:VIP 由主节点绑定,备用节点通过 VRRP 监控主节点状态,必要时接管。
- 健康检查脚本:通过
vrrp_script
定义服务存活状态检测脚本,结合权重变更实现节点切换。 - 优先级机制:高优先级节点会优先成为 MASTER,支持抢占或非抢占切换模式。
三、典型架构图
四、安装与配置 Keepalived(以 CentOS 为例)
4.1 安装 Keepalived
sudo yum install -y keepalived
4.2 配置主节点(MASTER)
/etc/keepalived/keepalived.conf
vrrp_script chk_nginx {
script "/etc/keepalived/chk_nginx.sh"
interval 2
fall 3
rise 3
weight -20
}
vrrp_instance VI_1 {
state MASTER
interface eth0
virtual_router_id