HAProxy 安全配置

在HAProxy案例中加入安全配置,可以参考以下步骤和示例配置。这个案例将展示如何在HAProxy中实现基本的安全措施,包括限制访问、启用HTTPS、配置HSTS以及使用ACLs进行细粒度控制。

1. 限制访问

使用ACLs来限制哪些IP地址或网络可以访问HAProxy服务。

plaintext 复制代码
frontend http_front
    bind *:80
    acl allowed_ips src 192.168.1.0/24
    http-request allow if allowed_ips
    http-request deny

2. 启用HTTPS

配置SSL/TLS证书来加密客户端和HAProxy之间的通信。

plaintext 复制代码
frontend https_front
    bind *:443 ssl crt /path/to/your/certificate.pem alpn h2,http/1.1
    default_backend https_back

3. 配置HSTS

启用HSTS头以防止协议降级攻击。

plaintext 复制代码
http-response set-header Strict-Transport-Security "max-age=31536000; includeSubDomains" if { ssl_fc }

4. 使用ACLs进行细粒度控制

通过ACLs实现更复杂的访问控制逻辑。

plaintext 复制代码
frontend https_front
    bind *:443 ssl crt /path/to/your/certificate.pem alpn h2,http/1.1
    acl is_admin path_beg /admin
    use_backend admin_backend if is_admin
    default_backend user_backend

backend admin_backend
    server admin_server 192.168.1.101:80 check

backend user_backend
    server user_server 192.168.1.102:80 check

5. 防止DDoS攻击

使用限速和连接数限制来减轻DDoS攻击的影响。

plaintext 复制代码
frontend https_front
    bind *:443 ssl crt /path/to/your/certificate.pem alpn h2,http/1.1
    limit_req zone=one burst=5 nodelay
    default_backend https_back

backend https_back
    balance roundrobin
    server web1 192.168.1.101:80 check
    server web2 192.168.1.102:80 check

完整示例配置

plaintext 复制代码
global
    log /dev/log local0
    maxconn 4096
    ssl-default-bind-ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES1:EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH

defaults
    log global
    mode http
    option httplog
    timeout connect 5000ms
    timeout client 50000ms
    timeout server 50000ms

frontend http_front
    bind *:80
    acl allowed_ips src 192.168.1.0/24
    http-request allow if allowed_ips
    http-request deny

frontend https_front
    bind *:443 ssl crt /path/to/your/certificate.pem alpn h2,http/1.1
    acl is_admin path_beg /admin
    use_backend admin_backend if is_admin
    default_backend user_backend
    http-response set-header Strict-Transport-Security "max-age=31536000; includeSubDomains" if { ssl_fc }
    limit_req zone=one burst=5 nodelay

backend admin_backend
    server admin_server 192.168.1.101:80 check

backend user_backend
    balance roundrobin
    server web1 192.168.1.101:80 check
    server web2 192.168.1.102:80 check

注意事项

  • 证书管理:确保SSL/TLS证书有效且安全。
  • 日志监控:定期检查HAProxy日志以发现异常行为。
  • 定期更新:保持HAProxy及其依赖库的最新版本。

通过这些配置,您可以显著提高HAProxy部署的安全性。务必根据您的具体环境和需求进行调整和优化。

相关推荐
yics.1 小时前
网络原理——初识网络
网络·计算机网络·通信基础
前端世界1 小时前
从零搭建多子网 DHCP 服务:CentOS 双网卡多作用域实战与原理解析
linux·运维·centos
xrkhy2 小时前
微服务之ShardingSphere
数据库·微服务·oracle
头发那是一根不剩了2 小时前
Docker Desktop 安装教程和最佳实践
运维·docker·容器
隐语SecretFlow2 小时前
【隐语SecretFlow】由蚂蚁集团牵头制定的“隐私保护计算安全分级”IEEE国际标准已正式发布!
大数据·网络·安全
JIngJaneIL2 小时前
停车场管理|停车预约管理|基于Springboot的停车场管理系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·停车场管理系统
煎蛋学姐2 小时前
SSM儿童福利院管理系统ys9w2d07(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·ssm 框架·儿童福利院管理系统
sg_knight2 小时前
MySQL 空间索引(SPATIAL)详解:地理位置数据的高效查询利器
数据库·mysql·database·索引·关系型数据库·空间索引·spatial
路由侠内网穿透.3 小时前
本地部署轻量级持续集成工具 Drone CI 并实现外部访问
运维·服务器·ci/cd·远程工作
节点小宝3 小时前
节点小宝与中兴路由合作升级:AX5400系列新增远程控网功能
服务器·网络·安全·智能路由器·远程工作