Eu odeio a sutileza aqui, mas tente adicionar um / no final de 9000 como abaixo. Ele não irá mais anexar "rota" à solicitação encaminhada agora.
location /route {
proxy_pass http://127.0.0.1:9000/;
}
O que eu quero fazer é
Quando alguém visitar http://localhost/route/abc
a resposta do servidor exatamente igual a http://localhost:9000/abc
Agora eu configuro meu Nginx assim:
location /route {
proxy_pass http://127.0.0.1:9000;
}
A solicitação http é enviada da porta 9000
corretamente, mas o caminho recebido é http://localhost:9000/route/abc
not http://localhost:9000/abc
.
Alguma sugestão?
Eu odeio a sutileza aqui, mas tente adicionar um / no final de 9000 como abaixo. Ele não irá mais anexar "rota" à solicitação encaminhada agora.
location /route {
proxy_pass http://127.0.0.1:9000/;
}
Acredito que você pode usar a reescrita para remover a parte extra do URL. No seu caso, acho que você poderia usar:
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;
}
No entanto, se seu aplicativo tiver links internos, eles ainda poderão apontar para / abc / foo e, se você fizer isso, eles precisarão apontar para / route / abc / foo para que a solicitação não processada seja recebida corretamente. Talvez seja melhor deixar a configuração do nginx como está e, em vez disso, configurar seu aplicativo para estar ciente de que ele mora em um subdiretório, se puder.
Eu sei que esta é uma pergunta antiga, mas foi o melhor hit do google para mim quando eu estava tentando resolver o mesmo problema!
Tente o seguinte
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;
}
vim 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/;
}
}
Este código escuta em 8080 e redireciona para a porta 8787 em compute-1-36. Você pode selecionar outro caminho na localização /