Как обслуживать все существующие статические файлы напрямую с NGINX, но остальные прокси-серверы для внутреннего сервера. - PullRequest
74 голосов
/ 15 мая 2009
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 обрабатывал все динамические файлы.

РЕДАКТИРОВАТЬ: Есть подход белого списка, но он не очень элегантный, смотрите все эти расширения, я не хочу этого.

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;
    }

РЕДАКТИРОВАТЬ 2: На более новых версиях Nginx используйте try_files вместо http://wiki.nginx.org/HttpCoreModule#try_files

Ответы [ 3 ]

141 голосов
/ 18 марта 2013

Используйте 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.

18 голосов
/ 17 мая 2009

Попробуйте это:

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. Остальные будут обрабатываться как статические файлы. Фактический алгоритм оценки местоположения здесь .

5 голосов
/ 13 февраля 2012

Если вы используете 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

...