it-swarm.com.de

Wie kann ich Nginx-Speicherorte so konfigurieren, dass gemeinsame Konfigurationsoptionen verwendet werden?

Wie kann ich einen gemeinsam genutzten Konfigurationsblock für eine Reihe von Speicherorten konfigurieren?

    location / {

            proxy_pass        http://127.0.0.1:9000/;
            proxy_redirect    off;
            proxy_set_header  Host             $http_Host;
            proxy_set_header  X-Real-IP        $remote_addr;
            proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;

            proxy_cache cache-test;
            proxy_cache_valid 200 302 24h;
            proxy_cache_valid 404 60s;
            add_header X-Cache-Status $upstream_cache_status;

    }


    location /api/0.1/user{
            proxy_cache_key /user/$http_authorization;
    }

Wenn ich jetzt versuche, auf /api/0.1/user zuzugreifen, erhalte ich 404, da die Anfrage nicht an 127.0.0.1:9000 weitergeleitet wird

43
netbrain

Erstellen Sie eine gemeinsame Proxy-Konfiguration und fügen Sie diese nach Bedarf hinzu.

/ etc/nginx/api_proxy.conf

proxy_pass        http://127.0.0.1:9000/;
proxy_redirect    off;
proxy_set_header  Host             $http_Host;
proxy_set_header  X-Real-IP        $remote_addr;
proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;

proxy_cache cache-test;
proxy_cache_valid 200 302 24h;
proxy_cache_valid 404 60s;
add_header X-Cache-Status $upstream_cache_status;

Ihre Host-Konfigurationsdatei

...
location /api/0.1/user {
    include /etc/nginx/api_proxy.conf;
    proxy_cache_key /user/$http_authorization;
}
...
57
SleighBoy

Die meisten Konfigurationsvariablen für proxy_ * sind auch im Serverkontext zulässig, sodass Sie sie nach oben verschieben können, um dieselben Einstellungen an mehreren Standorten gemeinsam zu nutzen.

Proxy_pass sollte jedoch nur innerhalb des Standorts verwendet werden. Sie sollten also mindestens diese Direktive an jedem Speicherort haben und optional die Werte einiger zusätzlicher proxy_ * -Vars überschreiben.

11