繁体   English   中英

haproxy后面的nginx静态html ssl获取真实IP地址

[英]nginx behind haproxy to static html ssl getting real IP address

我的问题是从 nginx 级别的网络获取“真实”IP 地址,通过 ssl 为静态 vuejs 站点提供服务。

我想屏蔽某些IP地址,如果我不能使用代理通行证,我如何获得真实的IP地址,因为我只链接到一个静态位置?

haproxy (tcp) (端口: 443) ==> 加密请求 ==> nginx (端口: 8085) 请求传递到 ==> '/' 位置获取用于范围阻塞的真实 IP。

另请参阅 nginx vhost 文件中的问题/评论。 我在这里是在正确的轨道上还是需要以完全不同的方式完成?

haproxy 设置:

frontend ssl_front_433 xx.xx.xx.xx:443
    mode tcp
    option tcplog
    use_backend ssl_nginx_backend_8085

backend ssl_nginx_backend_8085
    mode tcp
    balance roundrobin
    option  tcp-check
    server  srv-2 127.0.0.1:8085  check  fall 3 rise 2 inter 4s

nginx设置:

server {
   listen 8085 ssl;
   server_name mydomain;

   access_log /var/log/nginx/access.log;
   error_log  /var/log/nginx/error.log;

   ssl_certificate      ./fullchain.pem;
   ssl_certificate_key  ./privkey.pem;
   include include.d/ssl.conf;

   // I want to only allow certain ip addresses
   // haproxy of course always returns 127.0.0.1 thus this is not working 
   include include.d/ip_range.conf;  

   location / {
        //how to get the proxy headers to be applied here?
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_redirect off;
        // do I need a proxy pass and if so where should I pass to,
        // in order to use it with static html/js?
        // can I use an upstream to a static location?
        //proxy_pass http://;
        try_files $uri $uri/ /index.html;
   }
}

在 nginx 方面,您可以使用deny allallow范围来控制允许哪些 IP 地址或范围到您的服务器块,如下所示:

allow  192.168.1.0/24;
deny   all;

注意:nginx 文档始终是一个很好的起点,这里是通过 IP 地址和范围限制访问的文档。

首先,我会挑战你重新考虑为什么你需要一个带有 haproxy 的负载均衡器来处理像 html/css/js 静态站点这样简单的事情。 更多的基础设施引入了更多的复杂性。

其次,仅当您想将请求指向本地 wsgi 服务器时才需要 nginx 中的上游,例如,在您的情况下,这是静态内容,因此您不需要指向上游 - 除非您有某种 wsgi要将请求转发到的服务。

最后,对于 haproxy 仅将请求转发为 127.0.0.1,首先确保 IP 位于标头中(即X-Real-IP ),然后您可以尝试将类似的内容添加到您的 haproxy 配置( )中,如果您确实如此想要保持haproxy:

frontend all_https
  option forwardfor header X-Real-IP
  http-request set-header X-Real-IP %[src]

haproxy 文档也是保存源 IP 地址的好资源。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM