Как обслуживать все существующие статические файлы непосредственно с помощью 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
3 ответов:
использовать 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-скрипта под
/path/to/root/of/static/files. Это распространено в большинстве современных PHP-фреймворков. В случае, если ваши устаревшие php-проекты имеют как PHP-скрипты, так и статические файлы, смешанные в одной папке, вам может потребоваться белый список всех типов файлов, которые вы хотите nginx служить.
попробуйте это:
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, если только соответствующий . Остальные рассматриваются как статические файлы. Фактический алгоритм оценки местоположения здесь.
Если вы используете 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
Comments