Problem mit der Nginx-Proxy-Pass-Verkettung

Problem mit der Nginx-Proxy-Pass-Verkettung

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.

verwandte Informationen