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のリクエストもApacheに渡されて処理されるように、ルールから* .phpファイルを除外する必要があります。
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を使用してください