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部署的安全性。务必根据您的具体环境和需求进行调整和优化。

相关推荐
wrx繁星点点3 分钟前
行为型模式-策略模式详解
java·开发语言·数据结构·数据库·tomcat·hibernate·策略模式
沙漏无语5 分钟前
MySql5.7.26安装和配置
数据库
bug菌¹5 分钟前
滚雪球学MySQL[5.1讲]:事务与并发控制
数据库·mysql·oracle
看山还是山,看水还是。12 分钟前
安全运维类面试题
运维·服务器·网络·安全·安全威胁分析·测试覆盖率
小码哥呀18 分钟前
CentOS修改主机名
linux·运维·centos
boonya19 分钟前
CentOs-Stream-9 设置静态IP外网访问
linux·运维·centos
Deng Xiang22 分钟前
Centos 8安装VNC及多用户配置详细教程
linux·运维·服务器·python·centos
职场人参23 分钟前
怎么提取视频里的音频?非常简单的提取音频方法
linux·运维·网络·microsoft
root_1024 分钟前
centos 7 通过MegaCli 可以查询RAID硬盘
运维·服务器·数据库
Ljw...29 分钟前
Linux重定向
linux