我有一个使用FastCGI的webapp。此应用程序部署为不同的“站点”。我有一个应用程序的通用nginx配置,然后,我包括每个站点的upstrams和位置文件。每个站点都需要一些.js和.css文件。现在,我已经通过常规配置文件的root
设置了这些。我现在的要求是,我希望能够为不同的站点使用不同的.css和.js。因此,文件的查找应首先从站点/位置级别开始,如果未找到,则搜索常规root
。
一般的nginx conf文件是:
# Change this directory depending on the server
include /etc/nginx/conf.d/app/upstreams/*.conf;
server
{
server_name 24.39.17.76;
root /var/www/app/files/;
listen 443;
ssl on;
ssl_certificate /etc/nginx/conf.d/app/ssl/new/app.pem;
ssl_certificate_key /etc/nginx/conf.d/app/ssl/new/app.com.key;
location ~* ^.+\.(css|js|jpg|jpeg|gif|png|ico|svg|woff|ttf)$ {
access_log off; # this is because otherwise, with jail2ban the user may be banned
# add_header Access-Control-Allow-Origin "*";
expires max;
add_header Cache-Control "public, must-revalidate, proxy-revalidate";
add_header Pragma public;
}
# Change this directory depending on the server
include /etc/nginx/conf.d/app/locations/*.conf;
}
请注意我包含所有位置conf和上游文件的行。
然后一个特定的网站,有一个上游文件,如:
upstream siteX
{
server localhost:9021;
server localhost:9022;
server localhost:9023;
}
和这样的位置文件:
location ~ ^/siteX/reps {
access_log /var/log/nginx/app/siteX_reps_access.log;
error_log /var/log/nginx/app/siteX_reps_error info;
if ($arg_service = "true") {
rewrite ^/(.*)$ /service/$1 last;
}
rewrite ^/siteX/(.*)$ /$1 break;
try_files $uri @fastcgiSiteX;
}
location @fastcgiSiteX {
include fastcgi_params;
fastcgi_param REQUEST_URI $uri?$args;
fastcgi_pass fastcgiSiteX;
fastcgi_next_upstream error invalid_header http_500;
}
我的网页包含css和js的html是这样的:
<script type="text/javascript" src="/JQDevelopmentLibrary/jQuery.js"></script>
<link rel="stylesheet" type="text/css" href="/TBSDevelopmentLibrary/css/bootstrap.css"/>
但我可以轻松添加前缀,如果这有助于任何可能的解决方案,例如:
<script type="text/javascript" src="/siteX/webfiles/JQDevelopmentLibrary/jQuery.js"></script>
<link rel="stylesheet" type="text/css" href="/siteX/webfiles/TBSDevelopmentLibrary/css/bootstrap.css"/>
所以...一般文件在/ var / www / app / files /下。但是,我希望对于siteX,首先在另一条路径中搜索文件,比如说/ var / www / siteX / files,只有在找不到的情况下才搜索到这些文件。
我尝试但无效的一个解决方案是定义此try_files
表达式:
try_files /siteX/webfiles$uri $uri @fastcgiSiteX;
然后,我将所有文件夹和文件放在$ document_root / siteX / webfiles中,即/var/www/app/files/siteX/webfiles/
。我认为这个解决方案应该有效,但事实并非如此。
有什么想法吗?
提前致谢,
答案 0 :(得分:1)
它是一种黑客但它可以做到。
location ~ ^/siteX/reps {
access_log /var/log/nginx/app/siteX_reps_access.log;
error_log /var/log/nginx/app/siteX_reps_error info;
if ($arg_service = "true") {
rewrite ^/(.*)$ /service/$1 last;
}
rewrite ^/siteX/(.*)$ /$1 break;
try_files $uri @hack;
}
location @hack {
root /var/www/siteX/files;
try_files $uri $uri/ @fastcgiSiteX;
}
location @fastcgiSiteX {
include fastcgi_params;
fastcgi_param REQUEST_URI $uri?$args;
fastcgi_pass fastcgiSiteX;
fastcgi_next_upstream error invalid_header http_500;
}