Keepalived + HAProxy 实现高可用架构详解

目录

[🚀Keepalived + HAProxy 实现高可用架构详解](#🚀Keepalived + HAProxy 实现高可用架构详解)

🧠一、核心组件介绍

[1️⃣ HAProxy](#1️⃣ HAProxy)

[2️⃣ Keepalived](#2️⃣ Keepalived)

🔁二、整体架构图

🔍三、工作机制详解

[✅ 正常情况下:](#✅ 正常情况下:)

[⚠️ 主节点宕机时:](#⚠️ 主节点宕机时:)

🛠️四、关键配置示例

[1️⃣ Keepalived 主节点配置](#1️⃣ Keepalived 主节点配置)

[2️⃣ Keepalived 备节点配置](#2️⃣ Keepalived 备节点配置)

[3️⃣ HAProxy 简要配置](#3️⃣ HAProxy 简要配置)

✅五、为什么它能实现"高可用"?

🧪六、测试验证建议

📌七、总结与最佳实践

📚延伸阅读


🚀Keepalived + HAProxy 实现高可用架构详解

在现代互联网架构中,高可用性(High Availability,HA)是衡量系统稳定性的关键指标。Keepalived 与 HAProxy 的结合,是实现四层/七层负载均衡 + 主备切换的黄金组合。本文将深入解析其工作机制、实现方式,并提供部署示意。


🧠一、核心组件介绍

1️⃣ HAProxy

HAProxy 是一款稳定、高性能的 TCP/HTTP 负载均衡器,支持健康检查、SSL、连接池等,是流量分发的核心组件。

2️⃣ Keepalived

Keepalived 通过 VRRP(虚拟路由冗余协议)提供故障转移(Failover)能力。它负责维持一个 Virtual IP(VIP) 的主备绑定关系。


🔁二、整体架构图

复制代码
                +----------------------+
                |     Client (用户)    |
                +----------+-----------+
                           |
                           | 访问 VIP(如 192.168.1.100)
                           ▼
         +------------------------------------------+
         |          Virtual IP: 192.168.1.100        |
         |       (由 Keepalived 绑定在 Master 上)   |
         +--------------------+---------------------+
                              |
                 +------------+------------+
                 |                         |
        +--------v--------+       +--------v--------+
        | HAProxy 主节点  |       | HAProxy 备节点  |
        | Keepalived: Master |     | Keepalived: Backup |
        +-------------------+     +-------------------+
                |                          |
                ▼                          ▼
     后端服务群组(如 Nginx / Web / API / DB 等)

🔍三、工作机制详解

✅ 正常情况下:
  • VIP(如 192.168.1.100)绑定在 主节点(HAProxy + Keepalived Master)上;

  • 客户端所有请求都通过 VIP 访问主 HAProxy,后者将请求转发到后端服务;

  • 主节点定期通过 VRRP 发送心跳信号给备节点,表明自己处于"存活"状态。

⚠️ 主节点宕机时:
  • Keepalived 检测不到心跳;

  • 备节点自动接管 VIP,角色从 Backup 切换为 Master;

  • 客户端请求继续通过相同的 VIP 发起,但实际上已由备节点 HAProxy 接管,实现无缝切换。


🛠️四、关键配置示例

1️⃣ Keepalived 主节点配置
复制代码
vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 123456
    }
    virtual_ipaddress {
        192.168.1.100
    }
}
2️⃣ Keepalived 备节点配置
复制代码
vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 123456
    }
    virtual_ipaddress {
        192.168.1.100
    }
}
3️⃣ HAProxy 简要配置
复制代码
frontend http_front
    bind *:80
    default_backend servers

backend servers
    balance roundrobin
    server web1 192.168.1.201:80 check
    server web2 192.168.1.202:80 check

✅五、为什么它能实现"高可用"?

  1. VIP 不变,客户端感知不到主备切换

  2. Keepalived + VRRP 提供稳定的主备机制;

  3. HAProxy 提供强大的健康检查 + 负载均衡能力;

  4. 整个集群冗余设计,即便一台节点宕机,系统依旧可用。


🧪六、测试验证建议

  1. 正常状态: 访问 VIP,确认主节点响应;

  2. 断开主节点网络/关闭 Keepalived: 确认 VIP 是否漂移至备节点;

  3. 恢复主节点后是否回抢: 测试 nopreemptpreempt 的设置;

  4. 观察日志: journalctl -u keepalived / haproxy -db -f /etc/haproxy/haproxy.cfg


📌七、总结与最佳实践

  • 使用真实心跳 + VIP 接管机制 是高可用的本质;

  • VIP 配置不宜冲突,使用独立网卡或 IP 别名(如 eth0:1);

  • 可配合 Redis、MySQL、Nginx 等后端服务共同部署高可用集群;

  • 可以将 VIP 注册到 DNS 中,通过域名访问。


📚延伸阅读


如果你也在构建一套生产级的服务系统,这套 Keepalived + HAProxy 的方案值得首选,稳定、轻量、易部署,是企业私有云架构中的典范。

需要部署脚本、实战演练或集群 YAML 文件?欢迎评论区一起讨论!

相关推荐
晚霞的不甘13 小时前
CANN 支持多模态大模型:Qwen-VL 与 LLaVA 的端侧部署实战
人工智能·神经网络·架构·开源·音视频
消失的旧时光-194321 小时前
第十三课:权限系统如何设计?——RBAC 与 Spring Security 架构
java·架构·spring security·rbac
智慧地球(AI·Earth)1 天前
DeepSeek架构新探索!开源OCR 2诞生!
架构·ocr
范纹杉想快点毕业1 天前
实战级ZYNQ中断状态机FIFO设计
java·开发语言·驱动开发·设计模式·架构·mfc
pcm1235671 天前
设计C/S架构的IM通信软件(4)
java·c语言·架构
齐鲁大虾1 天前
Linux下用什么编程语言方便开发B/S架构程序
linux·运维·架构
Volunteer Technology1 天前
MinIo介绍和使用
架构
h7ml1 天前
淘宝返利软件的跨端同步架构:Java RESTful API+GraphQL满足Web/APP/小程序的多端数据需求
java·架构·restful
茂桑1 天前
DDD领域驱动设计-基础设施层
设计模式·架构
大转转FE1 天前
转转前端周刊第185期: 深度解析Moltbot 底层架构
架构