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