Nginx:如何将 HTTP 请求转发到另一个端口?

Nginx:如何将 HTTP 请求转发到另一个端口?

我想要做的是:当有人访问http://localhost/route/abc服务器时,响应与http://localhost:9000/abc

现在我像这样配置我的 Nginx 服务器:

location /route {
    proxy_pass  http://127.0.0.1:9000;
}

HTTP 请求被9000正确发送到端口,但是它接收的路径http://localhost:9000/route/abc不是http://localhost:9000/abc

有什么建议么?

答案1

我不喜欢这里的微妙之处,但请尝试像下面这样在 9000 的末尾添加一个 /。现在它将不再将“路由”附加到转发的请求中。

location /route {
    proxy_pass  http://127.0.0.1:9000/;
}

答案2

我相信您可以使用重写来删除 URL 的多余部分。对于您的情况,我认为您可以使用:

location /route/ {
    rewrite ^/route/?(.*)$ /$1 break;    
    proxy_pass  http://127.0.0.1:9000;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

但是,如果您的应用程序中有内部链接,它们可能仍指向 /abc/foo ,如果您这样做,它们需要指向 /route/abc/foo ,以便原始请求正确进入。如果可以的话,最好保留 nginx 配置,而是配置您的应用程序以了解它位于子目录中。

我知道这是一个老问题,但是当我尝试解决同一问题时,它是我谷歌上最热门的答案!

答案3

尝试以下操作

location /route/ {
        proxy_pass  http://127.0.0.1:9000;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}

答案4

vimnginx.conf

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;

  server {
    listen 8080;

    location / {
      proxy_pass http://compute-1-36:8787;
      proxy_redirect http://compute-1-36:8787/ $scheme://$host:8080/;
    }
  }
}

此代码监听 8080 并重定向到 compute-1-36 上的端口 8787。您可以在 location 中选择其他路径/

相关内容