Как обслуживать все существующие статические файлы непосредственно с помощью 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

805   3  

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

    Ничего не найдено.