docker 容器中的 Nginx 反向代理 - 记录了错误的 IP

min*_*cos 8 nginx docker

我使用以下配置在 Docker 容器中运行 Nginx 作为反向代理。它基本上将请求重定向到在同一台机器上运行的另一个 docker 容器

问题

问题是访问日志中的输出指出了错误的客户端 IP 地址,特别是我获取了 Docker 主机的 IP 172.17.0.1

172.17.0.1 - - [24/May/2016:19:50:18 +0000] "GET /admin/ HTTP/1.1" 200 19243 "-" "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:46.0) Gecko/20100101 Firefox/46.0" "-"

我试图遵循这篇文章中关于set_real_ip_from指令的建议,但没有任何成功。

配置

server {
    listen       8000 ssl;
    server_name  example.com;

    access_log  /var/log/nginx/host.access.log  main;

    ssl_certificate     /path/to/cert.pem;
    ssl_certificate_key /path/to/key.key;

    set_real_ip_from 172.17.0.1;
    real_ip_header X-Forwarded-For;
    real_ip_recursive on;

    proxy_set_header    Host $host:$server_port;
    proxy_set_header    X-Real-IP $remote_addr;
    proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header    X-Forwarded-Proto $scheme;

    location / {
        proxy_pass  http://172.17.0.1:8100/;
    }
}
Run Code Online (Sandbox Code Playgroud)

我在这里缺少什么?


编辑:

我刚刚意识到其他人在这里这里也有类似的问题,但不幸的是没有解决方案。

wom*_*ble 0

您需要在执行代理的计算机上设置X-Forwarded-For标头(不是,这甚至更不标准),并且您需要告诉接收请求的任何内容以信任 XFF 标头是合法的,因为它来自已知的 IP。您在问题中获得的配置仅适用于一台机器,但它具有两端所需的配置。X-Real-IP