Ich verwende nginx1.14.2als Reverse-Proxy mit folgender Konfiguration
server {
listen xxxxxxx:80;
server_name xxxxxx;
proxy_intercept_errors on;
location /nodejs {
proxy_pass https://nodejs.org;
proxy_cache cache;
proxy_cache_valid 200 301 302 30d;
proxy_cache_valid 404 1m;
expires 30d;
proxy_ssl_server_name on;
proxy_cache_use_stale error timeout invalid_header updating;
}
}
Ich erhalte502 Bad Gatewayim Browser:Bildbeschreibung hier eingeben In den Nginx-Fehlerprotokollen habe ich folgende Zeile gefunden:
2020/12/10 11:23:23 [error] 16462#16462: *1 connect() failed (110: Connection timed out) while connecting to upstream, client: xxxxxxx, server: xxxxxxxx, request: "GET /nodejs HTTP/1.1", upstream: "https://104.20.23.46:443/nodejs", host: "xxxxxxxx"
Da es im Backend jedoch einen Proxy gibt, wird die URL mit der IP-Adresse blockiert. Haben Sie eine Idee, wie Sie Nginx zwingen können, im Upstream den Domänennamen anstelle der IP-Adresse zu verwenden?
Danke.
Bearbeiten: Ich habe der Proxy_Pass-Konfiguration folgende Zeile hinzugefügt:
rewrite /nodejs/(.*) /dist break;
Jetzt sieht das Fehlerprotokoll so aus:
2020/12/10 12:22:37 [error] 16541#16541: *1 connect() failed (110: Connection timed out) while connecting to upstream, client: xxxxxxx, server: xxxxxxxx, request: "GET /nodejs HTTP/1.1", upstream: "https://104.20.22.46:443/dist", host: "xxxxxxx"
Antwort1
Sie benötigen diese Anweisung: proxy_ssl_server_name on;
Die Standardeinstellung ist „Aus“.
http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_ssl_server_name