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