Что я хочу делать: когда кто-то приходит 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
.
Какие-либо предложения?
Я ненавижу тонкости здесь, но попробуйте добавить / в конце 9000, как показано ниже. Теперь он больше не будет добавлять «маршрут» к перенаправленному запросу.
location /route {
proxy_pass http://127.0.0.1:9000/;
}
Я считаю, что вы можете использовать перезапись, чтобы удалить лишнюю часть 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, когда я пытался решить ту же проблему!
Попробуйте следующее
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/;
}
}
Этот код прослушивает 8080 и перенаправляет на порт 8787 на compute-1-36. Вы можете выбрать другой путь в location /