Nginx : http 요청을 다른 포트로 어떻게 전달합니까?


65

내가하고 싶은 것은

누군가 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.

어떠한 제안 ?

답변:


65

나는 여기서 미묘함을 싫어하지만 아래처럼 9000의 끝에 /를 추가하십시오. 더 이상 전달 된 요청에 "경로"를 추가하지 않습니다.

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

4
이것이 정답입니다. 단순히 추가하는 /것은 위치에 나열된 접두사를 제거하는 방법으로 잘 문서화되어 있습니다.
Bernard

40

다시 쓰기를 사용하여 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 설정을 그대로두고 대신 하위 디렉토리에있을 수 있도록 앱을 구성하는 것이 좋습니다.

나는 이것이 오래된 질문이라는 것을 알고 있지만 같은 문제를 해결하려고 할 때 가장 인기있는 구글이었습니다!


감사 ! 이 링크에서 변수 목록을 검토 할 수 있습니다 : wiki.nginx.org/HttpProxyModule#Variables
Edgard Leal

17

다음을 시도하십시오

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

이 솔루션은 호스트 이름을 유지하므로 가장 효과적입니다.
Shafique Jamal

깨끗하고 간단합니다.
Ravshan Samandarov

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

이 코드는 8080에서 수신 대기하며 계산 -1-36에서 포트 8787로 리디렉션됩니다. 위치에서 다른 경로를 선택할 수 있습니다 /

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.