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;
}
}
Ci-dessus servira tous les fichiers existants directement en utilisant Nginx (par exemple, Nginx n'affiche que le code source PHP), sinon transmettez une requête à Apache. Je dois exclure les fichiers * .php de la règle afin que les demandes de * .php soient également transmises à Apache et traitées.
Je veux que Nginx gère tous les fichiers statiques et qu'Apache traite tous les éléments dynamiques.
EDIT: Il y a une approche de liste blanche, mais ce n'est pas très élégant, voir toutes ces extensions, je ne veux pas de ça.
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;
}
EDIT 2: Sur les versions plus récentes de Nginx, utilisez try_files
plutôt http://wiki.nginx.org/HttpCoreModule#try_files