location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
if (-f $request_filename) {
access_log off;
expires 30d;
break;
}
if (!-f $request_filename) {
proxy_pass http://127.0.0.1:8080; # backend server listening
break;
}
}
上面将使用Nginx直接提供所有现有文件(例如Nginx只显示PHP源代码),否则将请求转发给Apache。我需要从规则中排除* .php文件,以便* .php的请求也传递给Apache并进行处理。
我希望Nginx处理所有静态文件,并希望Apache处理所有动态内容。
编辑:有白名单方法,但不是很优雅,看到所有这些扩展,我不想要这个。location ~* ^.+.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|js)$ {
access_log off;
expires 30d;
}
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8080;
}
编辑2:在较新版本的Nginx上使用try_files
代替http://wiki.nginx.org/HttpCoreModule#try_files
答案 0 :(得分:140)
使用try_files和命名的位置块('@apachesite')。这将删除不必要的正则表达式匹配和if块。效率更高。
location / {
root /path/to/root/of/static/files;
try_files $uri $uri/ @apachesite;
expires max;
access_log off;
}
location @apachesite {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8080;
}
更新:此配置的假设是/path/to/root/of/static/files
下不存在任何php脚本。这在大多数现代php框架中很常见。如果你的遗留php项目同时将php脚本和静态文件混合在同一个文件夹中,你可能需要将所有希望nginx服务的文件类型列入白名单。
答案 1 :(得分:18)
试试这个:
location / {
root /path/to/root;
expires 30d;
access_log off;
}
location ~* ^.*\.php$ {
if (!-f $request_filename) {
return 404;
}
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8080;
}
希望它有效。正则表达式的优先级高于普通字符串,因此如果只存在相应的.php
文件,那么以.php
结尾的所有请求都应该被提交给Apache。休息将作为静态文件处理。评估位置的实际算法是here。
答案 2 :(得分:5)
如果您使用mod_rewrite隐藏脚本的扩展名,或者您只是喜欢以/结尾的漂亮网址,那么您可能希望从另一个方向处理此问题。告诉nginx让任何带有非静态扩展的东西都能通过apache。例如:
location ~* ^.+\.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|pdf|txt|tar|wav|bmp|rtf|js|flv|swf|html|htm)$
{
root /path/to/static-content;
}
location ~* ^!.+\.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|pdf|txt|tar|wav|bmp|rtf|js|flv|swf|html|htm)$ {
if (!-f $request_filename) {
return 404;
}
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8080;
}
找到了此代码段的第一部分