내가 하고 싶은 것은 누군가가 방문하면 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 끝에 /를 추가해 보세요. 이제 더 이상 전달된 요청에 "경로"를 추가하지 않습니다.
location /route {
proxy_pass http://127.0.0.1:9000/;
}
답변2
재작성을 사용하여 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 구성을 그대로 두고 대신 하위 디렉터리에 있다는 것을 인식하도록 앱을 구성하는 것이 더 나을 수 있습니다.
나는 이것이 오래된 질문이라는 것을 알고 있지만 동일한 문제를 해결하려고 할 때 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로 리디렉션됩니다. 위치에서 다른 경로를 선택할 수 있습니다./