Я пытаюсь настроить Nginx для пересылки запросов к нескольким серверным службам с помощью proxy_pass.
Некоторые из них не поддерживают доступ из подпапки, поэтому мне нужно добавить перезапись, чтобы удалить подпапку, которая добавляется, чтобы разрешить доступ ко всем им с одного порта.
Какие-нибудь советы по улучшению перезаписи?
Выход завитка;
:~$ curl -I -k https://example.net/internal
HTTP/1.1 404 Not Found
Server: nginx/1.0.5
Date: Thu, 19 Jan 2012 22:30:46 GMT
Content-Type: text/html; charset=utf-8
Connection: keep-alive
Content-Length: 145
:~$ curl -I -k https://example.net/internal/
HTTP/1.1 200 OK
Server: nginx/1.0.5
Date: Thu, 19 Jan 2012 22:31:12 GMT
Content-Type: text/html
Connection: keep-alive
Content-Length: 1285
Accept-Ranges: bytes
Last-Modified: Wed, 18 Jan 2012 01:35:21 GMT
Файлы конфигурации;
proxy.conf
location /internal {
rewrite ^/internal/(.*) /$1 break;
proxy_pass http://localhost:8081/internal;
include proxy.inc;
}
.... more entries ....
сайты с поддержкой / основной
server {
listen 443;
server_name example.com;
server_name_in_redirect off;
include proxy.conf;
ssl on;
}
proxy.inc
proxy_connect_timeout 59s;
proxy_send_timeout 600;
proxy_read_timeout 600;
proxy_buffer_size 64k;
proxy_buffers 16 32k;
proxy_pass_header Set-Cookie;
proxy_redirect off;
proxy_hide_header Vary;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
proxy_set_header Accept-Encoding '';
proxy_ignore_headers Cache-Control Expires;
proxy_set_header Referer $http_referer;
proxy_set_header Host $host;
proxy_set_header Cookie $http_cookie;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Ssl on;
proxy_set_header X-Forwarded-Proto https;
Мы могли бы превратить ваш rewrite
намного уродливее учитывать эту строку (/internal
), не допуская непреднамеренных совпадений. (если вы хотите ((?:/.*|))
где у вас косая черта или похожий зверь), но уродливый менее ремонтопригоден.
Я склонен сказать, просто сделай это:
location /internal {
rewrite ^/internal$ https://example.net/internal/ permanent;
rewrite ^/internal/(.*) /$1 break;
proxy_pass http://localhost:8081/internal;
include proxy.inc;
}