Как обслуживать все существующие статические файлы напрямую с помощью NGINX, но прокси-сервер остаётся на сервере.
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 для обработки всех динамических материалов.
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
Ответы
Ответ 1
Используйте try_files и названный блок местоположения ('@apachesite'). Это приведет к удалению ненужного соответствия регулярных выражений и блокировке. Более эффективный.
location / {
root /path/to/root/of/static/files;
try_files $uri $uri/ @apachesite;
expires max;
access_log off;
}
location @apachesite {
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;
}
Обновление: Предполагается, что в этом случае не существует php script под /path/to/root/of/static/files
. Это часто встречается в большинстве современных php-фреймворков. Если ваши устаревшие проекты php имеют как php-скрипты, так и статические файлы, смешанные в одной папке, вам может потребоваться белый список всех типов файлов, которые вы хотите использовать nginx.
Ответ 2
Попробуйте следующее:
location / {
root /path/to/root;
expires 30d;
access_log off;
}
location ~* ^.*\.php$ {
if (!-f $request_filename) {
return 404;
}
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;
}
Надеюсь, это сработает. Регулярные выражения имеют более высокий приоритет, чем простые строки, поэтому все запросы, заканчивающиеся на .php
, должны быть обращены к Apache, если существует только соответствующий файл .php
. Отдых будет обрабатываться как статические файлы. Фактический алгоритм оценки местоположения здесь.
Ответ 3
Если вы используете mod_rewrite, чтобы скрыть расширение ваших сценариев, или если вам нравятся красивые URL-адреса, которые заканчиваются на /, тогда вы можете приблизиться к этому с другого направления. Скажите nginx, чтобы что-нибудь с нестатическим расширением перешло в apache. Например:
location ~* ^.+\.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|pdf|txt|tar|wav|bmp|rtf|js|flv|swf|html|htm)$
{
root /path/to/static-content;
}
location ~* ^!.+\.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|pdf|txt|tar|wav|bmp|rtf|js|flv|swf|html|htm)$ {
if (!-f $request_filename) {
return 404;
}
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;
}
Я нашел первую часть этого фрагмента над: http://code.google.com/p/scalr/wiki/NginxStatic