mirror of
https://github.com/jc21/nginx-proxy-manager.git
synced 2024-08-30 18:22:48 +00:00
6c1ae77a2a
If a custom location is currently set to proxy to a DNS hostname this hostname is cached by nginx. When the underlying IP for the hostname changes this will be cached in nginx until it is restarted. This behaviour is somewhat undesirable if utilising containers. This change sets the proxy_pass for custom locations into a variable and utilises said variable for routing to the upstream backend. This will ensure that nginx will utilise the resolver and resolve the hostname to the current IP instead of relying on the nginx cache.
47 lines
1.3 KiB
Plaintext
47 lines
1.3 KiB
Plaintext
location {{ path }} {
|
|
set $upstream {{ forward_scheme }}://{{ forward_host }}:{{ forward_port }}{{ forward_path }};
|
|
proxy_set_header Host $host;
|
|
proxy_set_header X-Forwarded-Scheme $scheme;
|
|
proxy_set_header X-Forwarded-Proto $scheme;
|
|
proxy_set_header X-Forwarded-For $remote_addr;
|
|
proxy_set_header X-Real-IP $remote_addr;
|
|
proxy_pass $upstream;
|
|
|
|
{% if access_list_id > 0 %}
|
|
{% if access_list.items.length > 0 %}
|
|
# Authorization
|
|
auth_basic "Authorization required";
|
|
auth_basic_user_file /data/access/{{ access_list_id }};
|
|
|
|
{{ access_list.passauth }}
|
|
{% endif %}
|
|
|
|
# Access Rules
|
|
{% for client in access_list.clients %}
|
|
{{- client.rule -}};
|
|
{% endfor %}deny all;
|
|
|
|
# Access checks must...
|
|
{% if access_list.satisfy %}
|
|
{{ access_list.satisfy }};
|
|
{% endif %}
|
|
|
|
{% endif %}
|
|
|
|
{% include "_assets.conf" %}
|
|
{% include "_exploits.conf" %}
|
|
|
|
{% include "_forced_ssl.conf" %}
|
|
{% include "_hsts.conf" %}
|
|
|
|
{% if allow_websocket_upgrade == 1 or allow_websocket_upgrade == true %}
|
|
proxy_set_header Upgrade $http_upgrade;
|
|
proxy_set_header Connection $http_connection;
|
|
proxy_http_version 1.1;
|
|
{% endif %}
|
|
|
|
|
|
{{ advanced_config }}
|
|
}
|
|
|