Ich versuche, Nginx so einzurichten, dass Anfragen mithilfe von Proxy_Pass an mehrere Backend-Dienste weitergeleitet werden.
Die Links auf den Seiten ohne abschließende Schrägstriche haben zwar https://
einen davor, werden aber auf eine HTTP-Anfrage mit abschließendem Schrägstrich umgeleitet – die mit „Verbindung abgelehnt“ endet. Ich möchte, dass diese Dienste nur über HTTPS verfügbar sind.
Wenn ein Link also zuhttps://example.com/internal/errorlogs
in einem Browser, wenn geladen https://example.com/internal/errorlogs
gibt Error Code 10061: Connection refused
(es leitet weiter zu http://example.com/internal/errorlogs/
)
Wenn ich den Trialing-Schrägstrich manuell anhänge, https://example.com/internal/errorlogs/
wird es geladen
Ich habe es mit verschiedenen nachgestellten Schrägstrichen versucht, die an den Proxypfad und den Speicherort in der Datei proxy.conf angehängt wurden, aber ohne Erfolg.server_name_in_redirect off;
Dies geschieht bei mehr als einer App unter Nginx und funktioniert im Apache Reverse Proxy
Konfigurationsdateien;
proxy.conf
location /internal {
proxy_pass http://localhost:8081/internal;
include proxy.inc;
}
.... more entries ....
Sites aktiviert/Haupt
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;
Curl-Ausgabe
-$ curl -I -k https://example.com/internal/errorlogs/
HTTP/1.1 200 OK
Server: nginx/1.0.5
Date: Thu, 24 Nov 2011 23:32:07 GMT
Content-Type: text/html;charset=utf-8
Connection: keep-alive
Content-Length: 14327
-$ curl -I -k https://example.com/internal/errorlogs
HTTP/1.1 301 Moved Permanently
Server: nginx/1.0.5
Date: Thu, 24 Nov 2011 23:32:11 GMT
Content-Type: text/html;charset=utf-8
Connection: keep-alive
Content-Length: 127
Location: http://example.com/internal/errorlogs/
Antwort1
Ich habe gesehen, dass Sie die server_name_in_redirect
Direktive hinzugefügt haben, aber Sie brauchen proxy_redirect
eine Direktive für die Standortsitzung
http://wiki.nginx.org/HttpProxyModule#proxy_redirect
Sie werden so etwas hinzufügen
proxy_redirect http://example.com/ /;