AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1005037
Accepted
cvanorman
cvanorman
Asked: 2020-02-29 13:04:24 +0800 CST2020-02-29 13:04:24 +0800 CST 2020-02-29 13:04:24 +0800 CST

带有 Nginx 反向代理的代理协议

  • 772

概述

我有一个指向 SaaS 应用程序 (BigCommerce) 的 Nginx 反向代理设置。虽然我的配置运行良好,但我无法确保客户端 IP显示在 SaaS 后端而不是反向代理 IP中。在 SaaS 后端,没有添加或使用受信任 IP 地址列表的机制set_real_ip_from,real_ip_header因此我的任务是proxy_protocol在反向代理上实施,以确保 IP 标头使用客户端的 IP 而不是通过反向代理传递它自己的。

配置

在http server上下文中

    proxy_set_header Host $host;
    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;
    proxy_set_header X-Forwarded-Host $host:$server_port;

    # support http 1.1 persistent connections
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection $connection_upgrade;

问题

当我在 http 服务器上下文(例如)中启用proxy_protocol我的指令时,我在 nginx中收到一个错误,在我的浏览器中收到一个错误。listenlisten 443 ssl http2 proxy_protocolBroken Headerconnection_reset

此外,我尝试proxy_protocol通过stream上下文启用,因为它在 Nginx 的“接受代理协议”文档中指定:

在stream上下文中

stream {
    server {
        listen 12345;
        proxy_pass example.com:12345;
        proxy_protocol on;
    }
}

我不熟悉,proxy_protocol所以我不知道我缺少什么才能使它正常工作。

从技术上讲,我真的试图让我的反向代理成为“透明代理”,但它似乎不适用于 SaaS 后端,因为它记录的是代理 IP 而不是客户端 IP。

nginx reverse-proxy transparent-proxy
  • 1 1 个回答
  • 8932 Views

1 个回答

  • Voted
  1. Best Answer
    Piotr P. Karwasz
    2020-02-29T15:18:31+08:002020-02-29T15:18:31+08:00

    你看错了方向:

    1. 该listen 443 ssh http2 proxy_protocol;指令(参见listen )启用对传入连接的代理协议的解析。您的浏览器不使用协议,因此出现Bad Header错误。如果您想查看代理协议的最小示例,请使用:

      openssl s_client -connect <nginx_ip>:https -crlf
      

      并输入:

      PROXY TCP4 10.0.0.1 10.0.0.1 443 443
      GET / HTTP/1.1
      Host: <nginx_host_name>
      

      后跟两个空行。

    2. 该proxy_protocol on;指令(参见proxy_protocol)将启用 Nginx 和 SaaS 服务器之间的代理协议。但是,后者不支持您所说的代理协议。你需要实现它。

    但是,如果nginx位于 SaaS 服务器和 Internet 之间的路径上,您还有第三种解决方案:

    1. 使用proxy_bind指令(参见proxy_bind)告诉nginx欺骗其源地址(使用来自客户端的源地址):

      proxy_bind $remote_addr transparent;
      
    2. nginx可以很容易地欺骗源地址,但是来自 SaaS 服务器的响应数据包将被路由到客户端而不是nginx。因此,您需要拦截来自 SaaS 服务器的数据包。你需要一个新的路由表,让我们transparent通过添加来调用它:

      100 transparent
      

      到/etc/iproute2/rt_tables. 然后您需要接受任何本地地址:

      ip route add local default dev lo table transparent
      

      最后,您需要添加一条防火墙规则,以强制对transparent从 SaaS 服务器返回的所有流量使用路由表(假设其地址为10.10.10.10):

      iptable -t mangle -A PREROUTING -p tcp -s 10.10.10.10 --sport 80 -m socket\
      --transparent -j MARK --set-mark 1
      ip rule add fwmark 1 lookup transparent
      
    • 2

相关问题

  • Gzip 与反向代理缓存

  • nginx 作为代理的行为

  • Nginx 学习资源 [关闭]

  • 提供 70,000 个静态文件 (jpg) 的最佳方式?

  • 在 Apache、LightTPD 和 Nginx Web 服务器上提供 PHP 5.x 应用程序的现状?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve