Я пытаюсь настроить Nginx для пересылки запросов к нескольким серверным службам с помощью proxy_pass.
Загрузка https://example.com/monit
работает, однако ссылки на странице предназначены для https://example.com/sshd
вместо того https://example.com/monit/sshd
Я использую monit 5.2.5
Я пробовал использовать приведенное ниже правило перезаписи и без него.
Файлы конфигурации;
proxy.conf
location /monit {
# rewrite /monit/(.*) /$1 break;
proxy_pass http://localhost:2812/;
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;
Я изменил правило перезаписи и обеспечил очистку кеша, и это работает;
location /monit {
rewrite ^/monit/(.*) /$1 break;
proxy_pass http://localhost:2812/;
include proxy.inc;
}
К сожалению, у monit нет конфигурации, которая позволяет ему определять BASE_URL своих запросов, что означает, что он всегда будет добавлять свои службы непосредственно в /, что нарушает ваш / monit proxymatch. :( Обходной путь, но, возможно, некрасивый, - назвать ваши службы мониторинга таким образом, чтобы вы могли сопоставить ЭТО имя в nginx.
Это единственный способ сделать это, если только вы каким-то образом не взломаете источник monit, чтобы изменить URL-адрес на http: // локальный: 2812 / monit / но я считаю, что это сложнее?
Другой вариант может заключаться в том, если вы можете запустить nginx на параллельном порту и просто переписать доступ к этому порту на URL-адрес / порт мониторинга, таким образом вы можете переписать / proxypass весь / вместо / monit, что заставит ссылки работать. Зависит от вашего общедоступного IP-адреса и доступных портов, но должен ли трюк?