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/abchttp://localhost:9000/abc

助言がありますか?

答え1

ここでの微妙な点は嫌いですが、以下のように 9000 の末尾に / を追加してみてください。これで、転送されたリクエストに「route」が追加されなくなります。

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

答え2

URL の余分な部分を削除するには、rewrite を使用できると思います。あなたの場合は、次の方法が使用できると思います。

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 構成をそのままにして、代わりにサブディレクトリにあることを認識するようにアプリを構成する方がよい場合があります。

これは古い質問だとはわかっていますが、私が同じ問題を解決しようとしていたときに、Google で一番ヒットした質問でした。

答え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

ヴィムnginx.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で他のパスを選択することもできます。/

関連情報