HAProxy 搭建 Web 集群

一. HAProxy 是什么

HAProxy 是开源、高性能、支持 TCP/HTTP 的负载均衡器与代理软件 ,专门用于将客户端流量均匀分发到多台后端服务器,实现高并发、高可用、流量调度、故障自动隔离

二. HAProxy 核心作用

  1. 负载均衡:把请求分摊到多台 Web 服务器,避免单点压力过大。
  2. 健康检查:自动检测后端节点存活,故障节点自动剔除,恢复后自动加入。
  3. 高可用:某台服务器宕机不影响整体业务,保证服务不间断。
  4. 会话保持:支持按 IP、Cookie 绑定用户到固定节点,适配需要 Session 的业务。
  5. 日志与监控:详细记录请求状态、响应时间、节点状态,便于运维排查。

三. HAProxy 与同类工具对比

  • LVS:性能最强,内核级转发,但搭建复杂,功能偏底层。
  • Nginx:轻量易用,适合 Web 反向代理,但健康检查弱、高并发不如 HAProxy。
  • HAProxy :兼顾性能与易用性,健康检查强、调度算法丰富、支持 TCP/HTTP,是 Web 集群主流选择。

四. 负载均衡三大核心调度算法

  1. RR(Round Robin)轮询按顺序轮流分配请求,简单公平,适合后端服务器配置相同的场景。
  2. LC(Least Connections)最少连接把新请求分给当前连接数最少的节点,动态适配,适合长连接业务。
  3. SH(Source Hashing)源地址哈希 根据客户端 IP 哈希计算,同一 IP 始终访问同一节点,实现会话保持

五. 实验环境

  • HAProxy 服务器:192.168.1.61
  • Nginx Web01:192.168.1.60
  • Nginx Web02:192.168.1.62
  • 系统:CentOS/RHEL,关闭防火墙与 SELinux
实验步骤
1. 两台 Nginx 服务器安装配置(步骤相同,页面不同)

安装依赖

复制代码
yum -y install pcre-devel zlib-devel gcc*

创建 Nginx 运行用户

复制代码
useradd -M -s /sbin/nologin nginx

解压、编译安装

复制代码
tar zxvf nginx-1.12.0.tar.gz
cd nginx-1.12.0/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
make && make install

制作软链接

复制代码
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

编写测试页面

复制代码
# Web01
echo "test web01" > /usr/local/nginx/html/test.html
# Web02
echo "test web02" > /usr/local/nginx/html/test.html

启动 Nginx

复制代码
nginx

验证端口

复制代码
netstat -anpt | grep nginx
2. HAProxy 安装
复制代码
dnf install haproxy -y
3. HAProxy 配置(/etc/haproxy/haproxy.cfg)

vim /etc/haproxy/haproxy.conf

复制代码
global
    log         127.0.0.1 local2
    chroot      /var/lib/haproxy
    pidfile     /var/run/haproxy.pid
    user        haproxy
    group       haproxy
    daemon
    maxconn     4000

defaults
    mode        http
    log         global
    option      httplog
    option      dontlognull
    retries     3
    timeout http-request    5s
    timeout queue         1m
    timeout connect     5s
    timeout client       1m
    timeout server      1m
    timeout http-keep-alive 5s
    timeout check       5s
    maxconn             3000

listen webcluster
    bind 0.0.0.0:80
    option httpchk GET /index.html
    balance roundrobin
    server inst1 192.168.1.60:80 check inter 2000 fall 3
    server inst2 192.168.1.62:80 check inter 2000 fall 3
4. 启动 HAProxy
复制代码
systemctl start haproxy
systemctl enable haproxy
5. 测试负载均衡

浏览器访问:http://192.168.1.61/test.html多次刷新,交替显示 web01/web02。

命令批量测试:

复制代码
for i in $(seq 10); do curl http://192.168.1.61/test.html; done
6. HAProxy 日志配置

修改 haproxy.cfg

复制代码
global
    log 127.0.0.1 local3

创建 rsyslog 配置

复制代码
vim /etc/rsyslog.d/haproxy.conf

写入:

复制代码
$ModLoad imudp
$UDPServerRun 514
local3.*     /var/log/haproxy.log
&~

重启服务

复制代码
systemctl restart rsyslog
systemctl restart haproxy

查看日志

复制代码
cat /var/log/haproxy.log

六. 总结

HAProxy 是一款高性能、开源的 TCP/HTTP 负载均衡器,专为 Web 集群高并发、高可用场景设计,可将客户端请求智能分发至多台后端服务器,实现流量分担、故障自动剔除与服务稳定运行。

它相比 LVS 更易部署,相比 Nginx 健康检查更强、并发能力更优,支持轮询、最少连接、源 IP 哈希等丰富调度算法,可灵活适配不同业务需求。通过完整的全局、默认、应用模块三层配置,结合健康检查与日志管理,能快速搭建稳定可靠的 Web 集群,有效解决单点故障与性能瓶颈,是生产环境中构建高可用 Web 服务的核心工具。

相关推荐
GISer_Jing2 小时前
Todos
前端·人工智能·学习
hresh2 小时前
两个 Chrome 窗口各 20 多个 tab 后,我把 tab-out 改成了更顺手的 TabNest
前端·chrome·后端
invicinble2 小时前
前端技术栈--vuecli页面固定思路解密,与vue-router技术栈信息
前端·javascript·vue.js
以神为界2 小时前
PHP与数据库交互实操:连接方法+SQL注入防范+系统数据库解析
数据库·sql·网络安全·php·web
shadowcz0072 小时前
CHI 2026 归来:AI/LLM 正在重写人机交互的底层语法
前端·人工智能·html·人机交互
Moment2 小时前
面试官:LangChain中 TS 和 Python 版本有什么差别,什么时候选TS ❓❓❓
前端·javascript·后端
JarvanMo2 小时前
SINT能否取代GetX?
前端
Mintopia2 小时前
深入理解计算机架构:从硬件到软件的桥梁
前端
大尚来也2 小时前
HTTPS的性能优化:从握手延迟到会话复用
前端