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, но прокси-сервер остаётся на сервере.
Я хочу, чтобы Nginx обрабатывал все статические файлы и Apache для обработки всех динамических материалов.
EDIT: Существует белый подход к списку, но он не очень изящный, см. Все эти расширения, я не хочу этого.
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: В новых версиях Nginx использовать try_files
вместо http://wiki.nginx.org/HttpCoreModule#try_files
Просто для того, чтобы очистить вещи: над кодом будет использоваться статический файл, если он существует на диске, если файл не существует, запрос передается Apache. Это работает большую часть времени, так как все URL-адреса в моих приложениях используют mod_rewrite (или маршрутизацию) и на самом деле не существуют на диске. Только прямой доступ к * .php filename является исключением и должен анализироваться Apache. –