私がやりたいのは、誰かが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 の末尾に / を追加してみてください。これで、転送されたリクエストに「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で他のパスを選択することもできます。/