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
发布于 2009-05-16 21:02:22
试试这个:
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拒绝。Rest将作为静态文件处理。评估位置的实际算法是here。
发布于 2012-02-14 03:37:06
如果您使用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
https://stackoverflow.com/questions/869001
复制相似问题