
networkcloudmanager/haproxy本镜像基于官方 haproxy:<sameTag> 构建,继承了 HAProxy 的全部功能特性。HAProxy 是一款高性能的 TCP/HTTP 负载均衡器和代理服务器,主要用于在多个后端服务实例之间分发网络流量,实现流量调度、服务高可用保障和性能优化。适用于需要提升服务可用性、扩展服务处理能力的场景。
HAProxy 核心配置通过 haproxy.cfg 文件定义,主要包含以下配置段:
plaintext# 全局配置 global log /dev/log local0 info maxconn 4096 daemon # 默认配置 defaults mode http log global timeout connect 5000ms timeout client 50000ms timeout server 50000ms # 前端配置(接收客户端请求) frontend http_front bind *:80 default_backend http_back # 后端配置(定义后端服务集群) backend http_back balance roundrobin # 使用轮询算法 server web1 192.168.1.10:80 weight 3 # 后端服务1,权重3 server web2 192.168.1.11:80 weight 1 # 后端服务2,权重1 server web3 192.168.1.12:80 backup # 备份服务,仅在主服务全部异常时启用
bashdocker run -d \ --name haproxy \ -p 80:80 \ -v /host/path/to/haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg:ro \ haproxy:<sameTag>
plaintextlisten stats bind *:1936 stats enable stats uri /haproxy-stats stats auth admin:admin123 # 监控页面认证
bashdocker run -d \ --name haproxy \ -p 80:80 \ -p 1936:1936 \ -v /host/path/to/haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg:ro \ haproxy:<sameTag>
yamlversion: '3' services: haproxy: image: haproxy:<sameTag> container_name: haproxy restart: always ports: - "80:80" # HTTP 服务端口 - "443:443" # HTTPS 服务端口(如需) - "1936:1936" # 监控页面端口 volumes: - ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg:ro - ./ssl:/etc/haproxy/ssl:ro # SSL 证书目录(如需) networks: - backend-network networks: backend-network: driver: bridge
修改配置文件后,无需重启容器,可通过以下命令实现热重载:
bashdocker exec haproxy haproxy -f /usr/local/etc/haproxy/haproxy.cfg -c # 验证配置 docker exec haproxy haproxy -f /usr/local/etc/haproxy/haproxy.cfg -sf $(cat /var/run/haproxy.pid) # 重载配置
本镜像本身不依赖固定环境变量,但可通过环境变量动态注入配置参数。例如,可结合 envsubst 实现配置文件模板化:
haproxy.template.cfg,包含变量占位符:plaintextbackend http_back balance roundrobin server web1 ${BACKEND_WEB1}:80 weight 3 server web2 ${BACKEND_WEB2}:80 weight 1
bashdocker run -d \ --name haproxy \ -e BACKEND_WEB1=192.168.1.10 \ -e BACKEND_WEB2=192.168.1.11 \ -v $(pwd)/haproxy.template.cfg:/tmp/haproxy.template.cfg \ haproxy:<sameTag> \ sh -c "envsubst < /tmp/haproxy.template.cfg > /usr/local/etc/haproxy/haproxy.cfg && haproxy -f /usr/local/etc/haproxy/haproxy.cfg"

manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务