我的一个虚拟服务器有以下nginx配置:
upstream app_example_https {
server 127.0.0.1:1340;
}
proxy_cache_path /Users/jaanus/dev/nginxcache levels=1:2 keys_zone=S3CACHE:10m;
proxy_cache_key "$scheme$request_method$host$request_uri";
server {
listen 0.0.0.0:1338;
server_name localhost;
ssl on;
ssl_certificate /Users/jaanus/dev/devHttpsCert.pem;
ssl_certificate_key /Users/jaanus/dev/devHttpsKey.pem;
location = / {
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_set_header Host 'something.s3-website-us-east-1.amazonaws.com';
proxy_set_header Authorization '';
proxy_hide_header x-amz-id-2;
proxy_hide_header x-amz-request-id;
proxy_hide_header Set-Cookie;
proxy_ignore_headers Set-Cookie;
proxy_cache S3CACHE;
proxy_cache_valid any 60m;
add_header X-Cached $upstream_cache_status;
proxy_pass http://something.s3-website-us-east-1.amazonaws.com/;
}
location /static/ {
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_set_header Host 'something.s3-website-us-east-1.amazonaws.com';
proxy_set_header Authorization '';
proxy_hide_header x-amz-id-2;
proxy_hide_header x-amz-request-id;
proxy_hide_header Set-Cookie;
proxy_ignore_headers Set-Cookie;
proxy_cache S3CACHE;
proxy_cache_valid any 60m;
add_header X-Cached $upstream_cache_status;
proxy_pass http://something.s3-website-us-east-1.amazonaws.com/static/;
}
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass http://app_example_https/;
proxy_redirect off;
}
}
这是用英语做的:
有一个nginx前端,可以从静态Amazon S3站点或应用服务器提供请求。
来自/(站点根目录)和/ static的所有请求都是从Amazon S3反向代理的。所有其他请求都是从应用程序服务器反向代理的。
现在,问题是:S3有两个几乎相同的位置块。这是我可以使这种配置工作的唯一方法,其中从S3提供两个特定文件夹(root和/ static),其他所有文件夹都转到应用程序服务器。
两个几乎相同的块看起来很笨,不可扩展。当我添加这样的文件夹时,我不想继续复制这些文件夹。
如何将两个位置合并到一个位置块中,同时保持一切工作方式相同?
答案 0 :(得分:2)
您可以将重复部分放入外部文件中include
。
<强> amazon.inc 强>
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_set_header Host 'something.s3-website-us-east-1.amazonaws.com';
proxy_set_header Authorization '';
proxy_hide_header x-amz-id-2;
proxy_hide_header x-amz-request-id;
proxy_hide_header Set-Cookie;
proxy_ignore_headers Set-Cookie;
proxy_cache S3CACHE;
proxy_cache_valid any 60m;
add_header X-Cached $upstream_cache_status;
proxy_pass http://something.s3-website-us-east-1.amazonaws.com;
您的配置
location = / {
include amazon.inc;
}
location /static/ {
include amazon.inc;
}
location / {
# proxy to you app
}
如果您希望将所有文件保存在一个文件中,则可以使用此技巧:
error_page 470 = @amazon;
location = / {
return 470;
}
location /static/ {
return 470;
}
location @amazon {
# proxy to amazon
}
您可以使用regexp将多个location
合并在一起,但我不建议这样做,因为它很难阅读和理解,并且效率低于简单的前缀位置。但是,仅作为一个例子:
# NOT RECOMMENDED
location ~ ^/($|static/) {
# proxy to amazon
}