如何配置 nginx 位置以共享常见的配置选项?

如何配置 nginx 位置以共享常见的配置选项?

如何为一系列位置配置共享配置块?

    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;
    }

现在,如果我尝试访问 /api/0.1/user,那么我将得到 404,因为它没有将请求传递到 127.0.0.1:9000

答案1

创建一个通用的代理配置并根据需要包含。

/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;

您的主机配置文件

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

答案2

大多数 proxy_* 配置变量也允许在服务器上下文中使用,因此您可以将它们向上移动以在多个位置共享相同的设置。

但是,proxy_pass 只能在位置内使用。因此,您至少应该在每个位置内使用此指令,并可选择覆盖一些额外的 proxy_* 变量的值。

相关内容