Nginx: Como encaminhar uma solicitação http para outra porta?


65

O que eu quero fazer é,

Quando alguém visita http://localhost/route/abca resposta do servidor exatamente da mesma forma quehttp://localhost:9000/abc

Agora eu configuro meu Nginx assim:

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

A solicitação http é a porta despachada 9000corretamente, mas o caminho recebido http://localhost:9000/route/abcnão é http://localhost:9000/abc.

Alguma sugestão ?

Respostas:


65

Eu odeio a sutileza aqui, mas tente adicionar um / no final de 9000 como abaixo. Ele não anexará mais "rota" à solicitação encaminhada agora.

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

4
Essa deve ser a resposta aceita. Simplesmente adicionar /é bem documentado como a maneira de remover o prefixo listado no local.
Bernard

40

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 o seu aplicativo tiver links internos, ele ainda poderá apontar para / abc / foo, e se você fizer isso, precisará apontar para / route / abc / foo para que a solicitação bruta seja recebida corretamente. É melhor deixar a configuração do nginx como está e, em vez disso, configurar o aplicativo para ficar ciente de que ele fica em um subdiretório, se você puder.

Sei que essa é uma pergunta antiga, mas foi o principal hit do Google para mim quando estava tentando resolver o mesmo problema!


Obrigado ! neste link que pode rever a lista de variáveis: wiki.nginx.org/HttpProxyModule#Variables
Edgard Leal

17

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;
}

Essa solução funcionou melhor para mim, pois preserva o nome do host.
Shafique Jamal

Limpo e simples.
Ravshan Samandarov 15/03

7

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/;
    }
  }

Esse código escuta no 8080 e redireciona para a porta 8787 no compute-1-36. Você pode selecionar outro caminho no local /

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.