如何为一系列位置配置共享配置块?
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_* 变量的值。