
Mein Setup ist wie folgt: Ich habe Server 1, der öffentlich zugänglich ist, und Server 2, der nur für Server 1 geöffnet ist.
Die Anfrage sollte an Server 1 gehen und dann an Server 2 weitergeleitet werden, der sie an eine lokal laufende Backend-App weiterleitet. Tatsächlich geht die Anfrage an den anderen/Standardserverblock und nicht an subdomain1.domain.com.
Wenn ich die Subdomain1.domain.com vom Server 1 curle, wird die Anfrage korrekt weitergeleitet. Was übersehe ich?
Ich habe auch versucht, etwas hinzuzufügen proxy_set_header Host $host;
, proxy_redirect off;
aber nichts hat funktioniert.
Server 1-Konfiguration:
upstream my-api {
server subdomain1.domain.com:80;
}
server {
listen 443 ssl http2;
server_name subdomain2.subdomain1.domain.com;
ssl_certificate /path/file.cert;
ssl_certificate_key /path/file.key;
access_log /var/log/nginx/my-api.access.log;
error_log /var/log/nginx/my-api.error.log;
location / {
proxy_pass http://my-api;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
server {
listen 80;
server_name subdomain2.subdomain1.domain.com;
return 301 https://$host$request_uri;
}
Server 2-Konfiguration:
server {
listen 80;
server_name subdomain1.domain.com;
access_log /var/log/nginx/api.en.access.log;
error_log /var/log/nginx/api.en.error.log;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_pass http://127.0.0.1:8001;
}
}
Antwort1
Habe es endlich herausgefunden.
Ich habe diese Zeile zur Server 1-Konfiguration hinzugefügt:proxy_set_header Host subdomain1.domain.com;
Nur dann landet es im richtigen Serverblock. Ich hoffe, es hilft auch jemand anderem.