Персональный
сайт
Игоря
Сысоева


 
english
 
sysoev.ru
 
nginx
 поехали!    
 документация    
 поддержка    
 изменения    
 скачать    
 ссылки    
 
mod_accel
mod_realip
mod_deflate
программирование
всякая всячина
windows
freebsd
apache
pppd
unix
web
 
обо мне
для писем
для денег
 

Директивы модуля ngx_http_core_module

 

16.11.2009

Содержание

Директивы
aio
alias
client_body_in_file_only
client_body_in_single_buffer
client_body_buffer_size
client_body_temp_path
client_body_timeout
client_header_buffer_size
client_header_timeout
client_max_body_size
default_type
directio
directio_alignment
error_page
if_modified_since
internal
keepalive_requests
keepalive_timeout
large_client_header_buffers
limit_except
limit_rate
limit_rate_after
listen
location
log_not_found
log_subrequest
merge_slashes
msie_padding
msie_refresh
open_file_cache
open_file_cache_errors
open_file_cache_min_uses
open_file_cache_valid
optimize_server_names
port_in_redirect
read_ahead
recursive_error_pages
reset_timedout_connection
resolver
resolver_timeout
root
satisfy
satisfy_any
send_timeout
sendfile
server
server_name
server_name_in_redirect
server_names_hash_max_size
server_names_hash_bucket_size
server_tokens
tcp_nodelay
tcp_nopush
try_files
types
underscores_in_headers
Встроенные переменные

Директивы


syntax: aio [on|off|sendfile]
default: aio off
context: http, server, location

Директива (0.8.11) разрешает или запрещает использовать файловый AIO во FreeBSD и Linux.

Во FreeBSD AIO можно использовать, начиная с FreeBSD 4.3 версии. AIO можно собрать в ядре статически

options VFS_AIO
или же подгрузить динамически
kldload aio

Во FreeBSD 5 и 6 при включении AIO статически или динамически на стадии загрузки ядра вся сетевая подсистема будет использовать GiantLock, что может негативно сказаться на производительности системы в целом. Эта зависимость устранена во FreeBSD-6.4 STABLE от 2009 года и во FreeBSD 7. Однако, начиная с FreeBSD 5.3, есть возможность включать AIO, не связывая сетевую подсистему GiantLock'ом — для этого модуль AIO нужно подгружать уже после загрузки ядра. В этом случае в /var/log/messages появится сообщение

WARNING: Network stack Giant-free, but aio requires Giant.
Consider adding 'options NET_WITH_GIANT' or setting debug.mpsafenet=0
которое можно смело проигнорировать.
Требование использовать GiantLock в AIO связано с тем, что FreeBSD поддерживает асинхронные вызовы aio_read()/aio_write() для работы с сокетами. Но поскольку nginx использует AIO только для работы с диском, то проблем не возникает.

Для работы AIO нужно выключить sendfile:

location  /video/ {
    sendfile        off;
    aio             on;
    output_buffers  1 64k;
}

Кроме того, начиная с FreeBSD 5.2.1 и nginx-0.8.12, AIO также можно использовать для подгрузки данных для sendfile():

location  /video/ {
    sendfile        on;
    tcp_nopush      on;
    aio             sendfile;
}
В такой конфигурации используется флаг SF_NODISKIO и sendfile() не блокируется на диске, а сообщает об отсутствии данных в памяти, после чего nginx инициирует асинхронную подгрузку данных, читая только один байт. При этом ядро FreeBSD подгружает в память первые 128K файла, однако при последующих чтениях файл подгружается частями только по 16K. Изменить это можно с помощью директивы read_ahead.

В Linux AIO можно использовать, только начиная с версии ядра 2.6.22, и, кроме того, ещё необходимо дополнительно включать directio, иначе чтение будет блокирующимся:

location  /video/ {
    aio             on;
    directio        512;
    output_buffers  1 128k;
}

Поскольку directio в Linux можно использовать только для чтения блоков, выравненных по 512 байт (или 4К для XFS), то невыравненный конец файла будет читаться блокировано. То же относится к запросам части ответа byte-ranges и к запросам FLV не с начала файла: чтение невыровненных начала и конца ответа будет блокирующимся. sendfile выключать не нужно, так как при использовании directio он выключается сам.


syntax: alias путь
default: нет
context: location

Директива задаёт замену для указанного location'а. Например, при такой конфигурации

location  /i/ {
    alias  /data/w3/images/;
}
на запрос "/i/top.gif" будет отдан файл "/data/w3/images/top.gif".

В значении пути можно использовать переменные.

Если директива alias используется внутри location'а, заданного регулярным выражением, то регулярное выражение должно содержать выделения, а директива alias — ссылки на эти выделения (0.7.40), например:

location ~ ^/users/(.+\.(?:gif|jpe?g|png))$ {
    alias  /data/w3/images/$1;
}

Если location и последняя часть значения директивы совпадают:

location  /images/ {
    alias  /data/w3/images/;
}
то лучше воспользоваться директивой root:
location  /images/ {
    root   /data/w3;
}


syntax: client_body_in_file_only on|clean|off
default: client_body_in_file_only off
context: http, server, location

Директива определяет, сохранять ли всё тело запроса клиента в файл. Директиву можно использовать для отладки и при использовании переменной $request_body_file или метода $r->request_body_file модуля ngx_http_perl_module.

При использовании параметра "on" временные файлы по окончании обработки запроса не удаляется.

Параметр "clean" разрешает удалять временные файлы, оставшиеся по окончании обработки запроса.


syntax: client_body_in_single_buffer on|off
default: client_body_in_single_buffer off
context: http, server, location

Директива определяет, хранить ли всё тело запроса клиента в одном буфере. Директива рекомендуется при использовании переменной $request_body для уменьшения операций копирования.


syntax: client_body_buffer_size размер
default: client_body_buffer_size 8k/16k
context: http, server, location

Директива задаёт размер буфера для чтения тела запроса клиента. Если тело запроса больше заданного буфера, то всё тело запроса или только его часть записывается во временный файл. По умолчанию размер одного буфера равен двум размерам страницы, в зависимости от платформы это или 8K, или 16K.


syntax: client_body_temp_path путь [ уровень1 [ уровень2 [ уровень3 ] ] ]
default: client_body_temp_path client_body_temp
context: http, server, location

Директива задаёт имя каталога для хранения временных файлов с телом запроса клиента. В каталоге может использоваться иерархия подкаталогов до трёх уровней. Например, при такой конфигурации

client_body_temp_path  /spool/nginx/client_temp 1 2;
имя временного будет такого вида:
/spool/nginx/client_temp/7/45/00000123457


syntax: client_body_timeout время
default: client_body_timeout 60
context: http, server, location

Директива задаёт таймаут при чтении тела запроса клиента. Таймаут устанавливается не на всю передачу тела запроса, а только между двумя операциями чтения. Если по истечении этого времени клиент ничего не передаст, то ему возвращается ошибка "Request time out" (408).


syntax: client_header_buffer_size размер
default: client_header_buffer_size 1k
context: http, server

Директива задаёт размер буфера для чтения заголовка запроса клиента. Для подавляющего большинства запросов вполне достаточно буфера размером в 1K. Однако если в запросе есть большие cookies или же запрос пришёл от wap-клиента, то он может не поместиться в 1K. Поэтому, если строка запроса или строка заголовка запроса не помещается полностью в этот буфер, то выделяются большие буферы, задаваемые директивой large_client_header_buffers.


syntax: client_header_timeout время
default: client_header_timeout 60
context: http, server

Директива задаёт таймаут при чтении заголовка запроса клиента. Если по истечении этого времени клиент не передаст полностью заголовок запроса, то ему возвращается ошибка "Request time out" (408).


syntax: client_max_body_size размер
default: client_max_body_size 1m
context: http, server, location

Директива задаёт максимально допустимый размер тела запроса клиента, указываемый в строке "Content-Length" в заголовке запроса. Если размер больше заданного, то клиенту возвращается ошибка "Request Entity Too Large" (413). Следует иметь в виду, что браузеры не умеют корректно показывать эту ошибку.


syntax: default_type MIME-тип
default: default_type text/plain
context: http, server, location

Директива задаёт MIME-тип ответов по умолчанию.


syntax: directio [размер|off]
default: directio off
context: http, server, location

Директива (0.7.7) разрешает использовать флаги O_DIRECT (FreeBSD, Linux), F_NOCACHE (Mac OS X) или функцию directio() (Solaris) при чтении файлов, размер которых больше либо равен указанному. Директива автоматически запрещает (0.7.15) использование sendfile'а для данного запроса. Рекомендуется использовать для больших файлов:

directio  4m;
или при использовании aio в Linux.


syntax: directio_alignment размер
default: directio_alignment 512
context: http, server, location

Директива (0.8.11) устанавливает выравнивание для directio. В большинстве случае достаточно выравнивания 512 байт, однако при использовании XFS под Linux его нужно увеличить до 4K.


syntax: error_page код [код ...] [=|=ответ] uri
default: нет
context: http, server, location, if в location

Директива задаёт URI, который будет показываться для указанных ошибок. Директивы наследуются с предыдущего уровня при условии, что на данном уровне не описаны свои директивы error_page. В URI можно использовать переменные.

Пример использования:

error_page   404          /404.html;
error_page   502 503 504  /50x.html;
error_page   403          http://example.com/forbidden.html;

Кроме того, можно поменять код ответа на другой, например:

error_page   404  =200  /empty.gif;

Если ошибочный ответ обрабатывается проксированным сервером или FastCGI-сервером и этот сервер может вернуть разные коды ответов, например, 200, 302, 401 или 404, то можно выдавать возвращаемый код:

error_page   404  =  /404.php;

Если при перенаправлении не нужно менять URI, то можно перенаправить обработку ошибки в именованный location:

location / {
    error_page   404  =  @fallback;
}

location @fallback {
    proxy_pass   http://backend;
}


syntax: if_modified_since [off|exact|before]
default: if_modified_since exact
context: http, server, location

Директива (0.7.24) определяет, как сравнивать время модификации ответа и время в заголовке запроса "If-Modified-Since":

  • off — не проверять заголовок запроса "If-Modified-Since" (0.7.34);
  • exact — точно совпадение;
  • before — время модификации ответа меньше или равно времени, заданному в заголовке запроса "If-Modified-Since".


syntax: internal
default: нет
context: location

Директива указывает, что данный location может использоваться только для внутренних запросов. Для внешних запросов будет возвращаться ошибка "Not found" (404). Внутренними запросами являются

  • запросы, перенаправленные директивой error_page;
  • подзапросы, формируемые командой include virtual модуля ngx_http_ssi_module;
  • запросы, изменённые директивой rewrite модуля ngx_http_rewrite_module.

Пример использования:

error_page   404   /404.html;

location  /404.html {
    internal;
}


syntax: keepalive_requests число
default: keepalive_requests 100
context: http, server, location

Директива (0.8.0) задаёт максимальное число запросов, которые можно сделать по одному keep-alive соединению.


syntax: keepalive_timeout время [время]
default: keepalive_timeout 75
context: http, server, location

Директива задаёт таймаут, в течение которого keep-alive соединение с клиентом не будет закрыто со стороны сервера. Второй параметр задаёт значение в строке "Keep-Alive: timeout=время" в заголовке ответа. Параметры могут отличаться друг от друга. Строку "Keep-Alive: timeout=время" понимают Mozilla и Konqueror. MSIE сам закрывает keep-alive соединение примерно через 60 секунд.


syntax: large_client_header_buffers число размер
default: large_client_header_buffers 4 4k/8k
context: http, server

Директива задаёт максимальное число и размер буферов для чтения большого заголовка запроса клиента. Строка запроса должна быть не больше размера одного буфера, иначе клиенту возвращается ошибка "Request URI too large" (414). Длинная строка заголовка запроса также должна быть не больше размера одного буфера, иначе клиенту возвращается ошибка "Bad request" (400). Буферы выделяются только по мере необходимости. По умолчанию размер одного буфера равен размеру страницы, в зависимости от платформы это или 4K, или 8K. Если по окончании обработки запроса соединение переходит в состояние keep-alive, то эти буферы освобождаются.


syntax: limit_except методы { ... }
default: нет
context: location

Директива ограничивает HTTP-методы, доступные внутри location. Метод GET также включает в себя метод HEAD. Для ограничения могут использоваться директивы модулей ngx_http_access_module и ngx_http_auth_basic_module:

limit_except  GET {
    allow  192.168.1.0/32;
    deny   all;
}
Обратите внимание, что данное ограничение будет выполняться для всех методов, кроме методов GET и HEAD.


syntax: limit_rate скорость
default: нет
context: http, server, location, if в location

Директива задаёт скорость передачи ответа клиенту. Скорость задаётся в байтах в секунду. Ограничение работает только для одного соединения, то есть, если клиент откроет 2 соединения, то суммарная скорость будет в 2 раза выше ограниченной.

Если необходимо ограничить скорость для части клиентов на уровне сервера, то директива limit_rate для этого не подходит. Вместо этого следует задать нужную скорость переменной $limit_rate:

server {

    if ($slow) {
        set $limit_rate  4k;
    }

    ...
}


syntax: limit_rate_after размер
default: нет
context: http, server, location, if в location

Директива (0.8.0) задаёт объём данных, после передачи которого начинает ограничиватся скорость передачи ответа клиенту, например:

location /flv/ {
    flv;
    limit_rate_after  500k;
    limit_rate        50k;
}


syntax: listen адрес:порт [default|default_server| [backlog=число | rcvbuf=размер | sndbuf=размер | accept_filter=фильтр | deferred | bind | ipv6only=[on|off] | ssl]]
default: listen *:80 | *:8000
context: server

Директива задаёт адрес и порт, на которых сервер принимает запросы. Можно указать только адрес или только порт, кроме того, адрес может быть именем сервера, например:

listen  127.0.0.1:8000;
listen  127.0.0.1;
listen  8000;
listen  *:8000;
listen  localhost:8000;
адреса IPv6 (0.7.36) задаются в квадратных скобках:
listen  [::]:8000;
listen  [fe80::1];

Если указан только адрес, то используется порт 80.

Если директива не указана, то используется порт *:80, если nginx работает с правами пользователя root, или порт *:8000.

Если у директивы есть параметр default, то сервер, в котором описана эта директива, будет сервером по умолчанию для указанной пары адрес:порт. Если же директив с параметром default нет, то сервером по умолчанию будет первый сервер, в котором описана пара адрес:порт. Начиная с версии 0.8.21, можно использовать параметр default_server.

В директиве listen с параметром default можно также указать несколько параметров, специфичных для системных вызовов listen(2) и bind(2). Начиная с версии 0.8.21, эти параметры можно задать в любой директиве listen, но только один раз для указанной пары адрес:порт.

  • backlog=число — задаёт параметр backlog в вызове listen(2). По умолчанию backlog равен -1 для FreeBSD и 511 для всех остальных платформ.
  • rcvbuf=размер — задаёт параметр SO_RCVBUF для слушающего сокета.
  • sndbuf=размер — задаёт параметр SO_SNDBUF для слушающего сокета.
  • accept_filter=фильтр — задаёт название accept-фильтра. Работает только на FreeBSD, можно использовать два фильтра — dataready и httpready. По сигналу -HUP accept-фильтр можно менять только в последних версиях FreeBSD, начиная с 6.0, 5.4-STABLE и 4.11-STABLE.
  • deferred — указывает использовать отложенный accept(2) на Linux с помощью опции TCP_DEFER_ACCEPT.
  • bind — указывает, что для данной пары адрес:порт нужно делать bind(2) отдельно. Дело в том, что если описаны несколько директив listen с одинаковым портом, но разными адресами и одна из директив listen слушает на всех адресах для данного порта (*:порт), то nginx сделает bind(2) только на *:порт. Необходимо учитывать, что в этом случае для определения адреса, на которой пришло соединение, делается системный вызов getsockname(). Если же используются параметры backlog, rcvbuf, sndbuf, accept_filter или deferred, то для данной пары адрес:порт bind(2) всегда делается отдельно.
  • ipv6only — параметр (0.7.42) задаёт значение параметра IPV6_V6ONLY для слушающего сокета. Установить этот параметр можно только один раз на старте.
  • ssl — параметр (0.7.14) не имеет отношения к системным вызовам listen(2) и bind(2), а позволяет указать, что все соединения, принимаемые на этом порту, должны работать в режиме SSL. Это позволяет задать компактную конфигурацию для сервера, работающего сразу в двух режимах — HTTP и HTTPS.
    listen  80;
    listen  443 default ssl;
    

Пример использования параметров:

listen  127.0.0.1 default accept_filter=dataready backlog=1024;


syntax: location [=|~|~*|^~|@] /uri/ { ... }
default: нет
context: server

Директива устанавливает конфигурацию в зависимости от URI запроса. location можно задать обычной строкой или регулярным выражением. Регулярные выражения задаются префиксом "~*" — без учёта регистра символов, и "~" — с учётом. Для определения соответствия location'а и запроса сначала проверяются location'ы, заданные обычными строками. Среди них ищется максимальное совпадение. Затем проверяются регулярные выражения. В отличие от обычных строк, они не сортируются, а проверяются в порядке их следования в конфигурационном файле. Проверка регулярных выражений прекращается после первого же совпадения. Если совпадение с регулярным выражением не найдено, то используется конфигурация максимально совпавшего location'а.

Для операционных систем, не чувствительных к регистру символов, таких как Mac OS X и Cygwin, проверка обычных строк делается без учёта регистра (0.7.7). Однако, сравнение ограничено только однобайтными locale'ями.

Регулярное выражение может содержать выделения (0.7.40), которые могут затем использоваться в других директивах.

Если нужно запретить проверку регулярных выражений после проверки обычных строк, то это можно сделать с помощью префикса "^~". Если у максимально совпавшего location'а есть этот префикс, то регулярные выражения не проверяются.

Кроме того, с помощью префикса "=" можно задать точное совпадение URI и location. При совпадении поиск сразу же прекращается, так как дальше искать не имеет смысла. Например, если запрос "/" очень частый, то указав "location = /", можно ускорить обработку этого запроса, так как поиск location прекратится после первого же сравнения.

Если запрос точно совпал с обычным location'ом без префиксов "=" и "^~", то поиск тоже сразу же прекращается и регулярные выражения также не проверяются.

Проиллюстрируем вышесказанное примером:

location  = / {
    [ конфигурация A ]
}

location  / {
    [ конфигурация B ]
}

location ^~ /images/ {
    [ конфигурация C ]
}

location ~* \.(gif|jpg|jpeg)$ {
    [ конфигурация D ]
}
Для запроса "/" будет выбрана конфигурация A, для запроса "/documents/document.html" — конфигурация B, для запроса "/images/1.gif" — конфигурация C, для запроса "/documents/1.jpg" — конфигурация D.

Префикс "@" задаёт именованный location. Такой location не используется при обычной обработке запросов, а предназначен только для перенаправления в него запросов.


syntax: log_not_found [on|off]
default: log_not_found on
context: http, server, location

Директива разрешает или запрещает записывать в error_log ошибки о том, что файл не найден.


syntax: log_subrequest [on|off]
default: log_subrequest off
context: http, server, location

Директива разрешает или запрещает записывать в access_log подзапросы.


syntax: merge_slashes [on|off]
default: merge_slashes on
context: http, server

Директива разрешает или запрещает объединять в URI два и более слэшей в один.

Необходимо иметь ввиду, что это объединение необходимо для корректной проверки location'ов и регулярных выражений. Например, запрос "//scripts/one.php" не попадает в

location /scripts/ {
    ...
}
и может быть обслужен как статический файл, поэтому он приводится в "/scripts/one.php".

Выключение объединения может понадобиться, если в URI используются имена, закодированные методом base64, который использует символ "/". Но по соображениям безопасности лучше избегать выключения объединения.

Если директива указана на уровне server в сервере по умолчанию, то её значение распространяется на все виртуальные сервера, слушающие на том же адресе и порту.


syntax: msie_padding [on|off]
default: msie_padding on
context: http, server, location

Директива разрешает или запрещает добавлять в ответы для MSIE со статусом больше 400 комментарий для увеличения размера ответа до 512 байт.


syntax: msie_refresh [on|off]
default: msie_refresh off
context: http, server, location

Директива разрешает или запрещает выдавать для MSIE refresh'ы вместо редиректов.


syntax: open_file_cache max=N [inactive=время]|off
default: open_file_cache off
context: http, server, location

Директива задаёт кэш, в котором могут хранится

  • дескрипторы открытых файлов, информация об их размерах и времени модификации;
  • информация о существовании каталогов;
  • информация об ошибках поиска файла — нет файла, нет прав на чтение и тому подобное. Кэширование ошибок нужно разрешить директивой open_file_cache_errors.

Параметры директивы:

  • max — задаёт максимальное число элементов в кэше; при переполнении кэша удаляются наиболее давно не используемые элементы (LRU);
  • inactive — задаёт время, после которого элемент кэша удаляется, если к нему не было обращений в течение этого времени; по умолчанию 60 секунд;
  • off — запрещает кэш.

Пример использования:

open_file_cache          max=1000  inactive=20s;
open_file_cache_valid    30s;
open_file_cache_min_uses 2;
open_file_cache_errors   on;


syntax: open_file_cache_errors on|off
default: open_file_cache_errors off
context: http, server, location

Директива определяет, кэшировать или нет ошибки поиска файлов в open_file_cache.


syntax: open_file_cache_min_uses число
default: open_file_cache_min_uses 1
context: http, server, location

Директива определяет минимальное число использований файла в течение времени, заданного параметром inactive в директиве open_file_cache, после которого дескриптор файла будет оставаться открытым в кэше.


syntax: open_file_cache_valid время
default: open_file_cache_valid 60
context: http, server, location

Директива определяет, через какое время нужно проверять актуальность информации об элементе в open_file_cache.


syntax: optimize_server_names [on|off]
default: optimize_server_names on
context: http, server

Устаревшая директива.

Директива разрешает или запрещает оптимизировать проверку имени хоста в name-based виртуальных серверах. Проверка в частности влияет на имя хоста, используемого в редиректах. Если оптимизация разрешена и все name-based сервера, слушающие на одной паре адрес:порт, имеют одинаковую конфигурацию, то во время исполнения запроса имена не проверяются и в редиректах используется первое имя сервера. Если в редиректе нужно использовать имя хоста, переданное клиентом, то оптимизацию нужно выключить.


syntax: port_in_redirect [on|off]
default: port_in_redirect on
context: http, server, location

Директива разрешает или запрещает указывать порт в редиректах, выдаваемых nginx'ом.


syntax: read_ahead размер
default: read_ahead 0
context: http, server, location

Директива задаёт ядру размер предчтения при работе с файлами. Под Линуксом используется системный вызов

posix_fadvise(0, 0, 0, POSIX_FADV_SEQUENTIAL);
поэтому размер игнорируется.

Под FreeBSD используется fcntl(O_READAHEAD, размер), появившийся во FreeBSD-9 CURRENT. Для FreeBSD 7 нужно установить патч.


syntax: recursive_error_pages [on|off]
default: recursive_error_pages off
context: http, server, location

Директива разрешает или запрещает делать несколько перенаправлений через директиву error_page.


syntax: reset_timedout_connection [on|off]
default: reset_timedout_connection off
context: http, server, location

Директива разрешает или запрещает сбрасывать соединение по таймауту. Сброс делается следующим образом — перед закрытием сокета для него ставится опция SO_LINGER с таймаутом 0. После чего при закрытии сокета клиенту отсылается пакет RST, а всё память, связанная с этим сокетом, освобождается. Это позволяет избежать длительного нахождения уже закрытого сокета в состоянии FIN_WAIT1 с заполненными буферами.

Необходимо отметить, что соединения, находящиеся в состоянии keepalive, по истечении таймаута закрываются обычным образом.


syntax: resolver адрес
default: нет
context: http, server, location

Директива задаёт адрес name-сервера, например:

    resolver   127.0.0.1;


syntax: resolver_timeout время
default: resolver_timeout 30s
context: http, server, location

Директива задаёт таймаут для определения имени, например:

    resolver_timeout   5s;


syntax: root путь
default: root html
context: http, server, location, if в location

Директива задаёт корневой каталог для запросов. Например, при такой конфигурации

    location  /i/ {
        root  /data/w3;
    }
на запрос "/i/top.gif" будет отдан файл "/data/w3/i/top.gif".

В значении пути можно использовать переменные.

Путь к файлу формируется как простое добавление URI к значению директивы root. Если же необходима модификация URI, то нужно воспользоваться директивой alias.


syntax: satisfy all|any
default: satisfy all
context: location

Директива разрешает доступ при хотя бы одной успешной проверке, выполненной модулями ngx_http_access_module или ngx_http_auth_basic_module:

location / {
    satisfy  any;

    allow  192.168.1.0/32;
    deny   all;

    auth_basic            "closed site";
    auth_basic_user_file  conf/htpasswd;
}


syntax: satisfy_any on|off
default: satisfy_any off
context: location

Директива переименована в директиву satisfy.


syntax: send_timeout время
default: send_timeout 60
context: http, server, location

Директива задаёт таймаут при передаче ответа клиенту. Таймаут устанавливается не на всю передачу ответа, а только между двумя операциями записями. Если по истечении этого времени клиент ничего не примет, то nginx закрывает соединение.


syntax: sendfile [on|off]
default: sendfile off
context: http, server, location

Директива разрешает или запрещает использовать sendfile().


syntax: server { ... }
default: нет
context: http

Директива задаёт конфигурацию для виртуального сервера. Чёткого разделения виртуальных серверов ip-based (на основании ip-адреса) и name-based (на основании имени, передаваемого в строке "Host" заголовка запроса), нет. Вместо этого директивами listen описываются все адреса и порты, на которых нужно принимать соединения для этого сервера, и в директиве server_name указываются все имена серверов. Пример конфигурации описан в настройке виртуальных серверов.


syntax: server_name имя [...]
default: server_name hostname
context: server

Директива задаёт имена виртуального сервера, например:

server {
    server_name   example.com  www.example.com;
}

Первое имя становится основным именем сервера. По умолчанию используется имя машины (hostname). В именах серверов можно использовать "*" для замены первой или последней части имени:

server {
    server_name   example.com  *.example.com  www.example.*;
}

Два первых вышеприведённых имени можно объединить в одно:

server {
    server_name   .example.com;
}

Кроме того, в качестве имени сервера можно использовать регулярное выражение, указав перед ним "~":

server {
    server_name   www.example.com   ~^www\d+\.example\.com$;
}

Регулярное выражение может содержать выделения (0.7.40), которые могут затем использоваться в других директивах:

server {
    server_name   ~^(www\.)?(.+)$;

    location / {
        root  /sites/$2;
    }
}

server {
    server_name   _;

    location / {
        root  /sites/default;
    }
}

Начиная с 0.8.25, именованные выделения в регулярном выражении создают переменные, которые могут затем использоваться в других директивах:

server {
    server_name   ~^(www\.)?(?<domain>.+)$;

    location / {
        root  /sites/$domain;
    }
}

server {
    server_name   _;

    location / {
        root  /sites/default;
    }
}

Начиная с 0.7.11, можно использовать пустое имя "":

server {
    server_name   www.example.com   "";
}
что позволяет обрабатывать запросы без строки "Host" в заголовке запроса в этом сервере, а не в сервере по умолчанию для данной пары адрес:порт.

Порядок проверки имён следующий:

  • полные имена,
  • имена с маской в начале имени — *.example.com,
  • имена с маской в конце имени — mail.*,
  • регулярные выражения.


syntax: server_name_in_redirect [on|off]
default: server_name_in_redirect on
context: http, server, location

Директива разрешает или запрещает использовать в редиректах, выдаваемых nginx'ом, основное имя сервера, задаваемое директивой server_name. Если использование основного имени запрещено, то используется имя, указанного в строке "Host" в заголовке запроса. Если же этой строки нет, то используется IP-адрес сервера.


syntax: server_names_hash_max_size число
default: server_names_hash_max_size 512
context: http

Директива задаёт максимальный размер хэш-таблиц имён серверов. Подробнее смотри в описании настройки хэшей.


syntax: server_names_hash_bucket_size число
default: server_names_hash_bucket_size 32/64/128
context: http

Директива задаёт размер корзины в хэш-таблицах имён серверов. Значение по умолчанию зависит от размера строки кэша процессора. Подробнее смотри в описании настройки хэшей.


syntax: server_tokens [on|off]
default: server_tokens on
context: http, server, location

Директива разрешает или запрещает выдавать версию nginx'а в сообщениях об ошибках и в строке заголовка ответа "Server".


syntax: tcp_nodelay [on|off]
default: tcp_nodelay on
context: http, server, location

Директива разрешает или запрещает использовать опцию TCP_NODELAY. Опция включаются только при переходе соединения в состояние keep-alive.


syntax: tcp_nopush [on|off]
default: tcp_nopush off
context: http, server, location

Директива разрешает или запрещает использовать опции TCP_NOPUSH во FreeBSD или TCP_CORK в Linux. Опции включаются только при использовании sendfile. Включение опции позволяет

  • передавать заголовок ответа и начало файла в одном пакете в Linux и во FreeBSD 4.x;
  • передавать файл в полных пакетах.


syntax: try_files файл [файл ...] (uri|=код)
default: нет
context: location

Директива проверяет существование файлов в заданном порядке и использует для обработки запроса первый найденный файл, причём обработка делается в контексте этого же location'а. С помощью слэша в конце имени можно задать проверку существования каталога, например, так — "$uri/". В случае, если ни один файл не найден, то делается внутренний редирект на последний параметр. Последний параметр может быть кодом (0.7.51):

location / {
    try_files      $uri  $uri/index.html  $uri.html  =404;
}

Пример использования при проксировании Mongrel:

location / {
    try_files      /system/maintenance.html
                   $uri  $uri/index.html  $uri.html
                   @mongrel;
}

location @mongrel {
    proxy_pass     http://mongrel;
}

Пример использования вместе с Drupal/FastCGI:

location / {
    try_files      $uri  $uri/  @drupal;
}

location ~ \.php$ {
    try_files      $uri  @drupal;

    fastcgi_pass   ...;

    fastcgi_param  SCRIPT_FILENAME  /path/to$fastcgi_script_name;
    fastcgi_param  SCRIPT_NAME      $fastcgi_script_name;
    fastcgi_param  QUERY_STRING     $args;

    ... прочие fastcgi_param
}

location @drupal {
    fastcgi_pass   ...;

    fastcgi_param  SCRIPT_FILENAME  /path/to/index.php;
    fastcgi_param  SCRIPT_NAME      /index.php;
    fastcgi_param  QUERY_STRING     q=$uri&$args;

    ... прочие fastcgi_param
}
В этом примере директива try_files
location / {
    try_files      $uri  $uri/  @drupal;
}
аналогична директивам
location / {
    error_page     404 = @drupal;
    log_not_found  off;
}
А здесь
location ~ \.php$ {
    try_files      $uri  @drupal;

    fastcgi_pass   ...;

    fastcgi_param  SCRIPT_FILENAME  /path/to$fastcgi_script_name;

    ...
}
try_files тестирует существование PHP-файла, прежде чем передать запрос FastCGI-серверу.

Пример использования вместе с Wordpress и Joomla:

location / {
    try_files      $uri  $uri/  @wordpress;
}

location ~ \.php$ {
    try_files      $uri  @wordpress;

    fastcgi_pass   ...;

    fastcgi_param  SCRIPT_FILENAME  /path/to$fastcgi_script_name;
    ... прочие fastcgi_param
}

location @wordpress {
    fastcgi_pass   ...;

    fastcgi_param  SCRIPT_FILENAME  /path/to/index.php;
    ... прочие fastcgi_param
}


syntax: types { ... }
context: http, server, location

Директива задаёт соответствие расширения и MIME-типов ответов. Одному MIME-типу может соответствовать несколько расширений. По умолчанию используется такие соответствия:

types {
    text/html    html;
    image/gif    gif;
    image/jpeg   jpg;
}

Достаточно полная таблица соответствий входит в дистрибутив и находится в файле conf/mime.types.

Для того, чтобы для определённого location'а для всех ответов выдавался MIME-тип "application/octet-stream", можно использовать следующее:

location /download/ {
    types         { }
    default_type  application/octet-stream;
}


syntax: underscores_in_headers [on|off]
default: underscores_in_headers off
context: http, server

Директива разрешает или запрещает использование символов подчёркивания в строках заголовка запроса клиента.


Встроенные переменные

Модуль ngx_http_core_module поддерживает встроенные переменные, имена которых совпадают с именами переменных в Apache. Прежде всего, это переменные, представляющие из себя строки заголовка запроса клиента, например, $http_user_agent, $http_cookie и тому подобное. Кроме того, есть и другие переменные:

  • $args, эта переменная равна аргументам в строке запроса;
  • $arg_name, эта переменная равна аргументу name в строке запроса;
  • $binary_remote_addr, эта переменная равна адресу клиента в бинарном виде, длина её значения всегда 4 байта;
  • $content_length, эта переменная равна строке "Content-Length" в заголовке запроса;
  • $content_type, эта переменная равна строке "Content-Type" в заголовке запроса;
  • $cookie_name, эта переменная равна cookie name;
  • $document_root, эта переменная равна значению директивы root для текущего запроса;
  • $document_uri, то же самое, что и $uri;
  • $host, эта переменная равна строке "Host" в заголовке запроса или имени сервера, на который пришёл запрос, если этой строки нет;
  • $hostname, эта переменная равна имени хоста;
  • $http_name, эта переменная равна строке name в заголовке запроса;
  • $is_args, эта переменная равна "?", если в строке запроса есть аргументы, и пустой строке, если их нет;
  • $limit_rate, эта переменная позволяет установить ограничение скорости соединения;
  • $pid, эта переменная равна номеру рабочего процесса;
  • $request_method, эта переменная равна методу запроса, обычно это "GET" или "POST";
  • $remote_addr, эта переменная равна адресу клиента;
  • $remote_port, эта переменная равна порту клиента;
  • $remote_user, эта переменная равна имени пользователя, используемого в Basic аутентификации;
  • $realpath_root, эта переменная равна значению директивы root для текущего запроса, при этом все символические ссылки преобразованы в реальные путь;
  • $request_filename, эта переменная равна пути к файлу для текущего запроса, формируемому из директив root или alias и URI запроса;
  • $request_body, эта переменная содержит тело запроса. Значение переменной появляется в location'ах, обрабатываемых директивами proxy_pass и fastcgi_pass.
  • $request_body_file, эта переменная равна имени временного файла, в котором хранится тело запроса. По завершению работы файл необходимо удалить. Для того, чтобы тело запроса клиента всегда записывалось в файл, нужно указать client_body_in_file_only on. При передаче имени в проксированном запросе или в запросе к FastCGI-серверу следует запретить передачу самого тела директивами "proxy_pass_request_body off" или "fastcgi_pass_request_body off" соответственно.
  • $request_uri, эта переменная равна полному первоначальному URI вместе с аргументами;
  • $query_string, то же самое, что и $args;
  • $scheme, эта переменная равна схеме запроса — "http" или "https";
  • $server_protocol, эта переменная равна протоколу запроса, обычно это "HTTP/1.0" или "HTTP/1.1";
  • $server_addr, эта переменная равна адресу сервера, на который пришёл запрос. Как правило, для получения значения этой переменной делается один системный вызов. Для того, чтобы избежать системного вызова, нужно указывать адреса в директивах listen и использовать параметр bind;
  • $server_name, эта переменная равна имени сервера, на который пришёл запрос;
  • $server_port, эта переменная равна порту сервера, на который пришёл запрос;
  • $uri, эта переменная равна текущему URI в запросе, он может отличаться от первоначального, например, при внутренних редиректах или при использовании индексных файлов.

(C) Игорь Сысоев
http://sysoev.ru