【发布时间】:2010-10-26 12:31:53
【问题描述】:
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;
}
}
Above 将直接使用 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
【问题讨论】:
-
只是为了澄清一下:如果磁盘上存在静态文件,上面的代码将提供一个静态文件,如果该文件不存在,则将请求传递给 Apache。这在大多数情况下都有效,因为我的应用程序中的所有 URL 都使用 mod_rewrite(或路由)并且实际上并不存在于磁盘上。只有直接访问*.php文件名是例外,需要Apache解析。
标签: nginx reverse-proxy static-files