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
使用 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 服务的所有文件类型列入白名单。
尝试这个:
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。
如果您使用 mod_rewrite 来隐藏脚本的扩展名,或者您只是喜欢以 / 结尾的漂亮 URL,那么您可能想从另一个方向处理这个问题。告诉 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;
}
我在以下位置找到了此代码段的第一部分:http://code.google.com/p/scalr/wiki/NginxStatic
$uri/
,那么它可以工作。root /path/to/root/of/*static*/files;
。 php 文件应放在不同的文件夹中,不能直接从 Internet 访问。