# HG changeset patch # User Ruslan Ermilov # Date 1319258895 0 # Node ID edf8c90f80857dc25f7bfafe6d899b14c8bce2eb # Parent 0991bf45cbb8205f62a8bdb09b6858562fd0e6ca Renamed ngx_http_upstream to ngx_http_upstream_module. diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/GNUmakefile --- a/xml/ru/GNUmakefile Fri Oct 21 21:16:08 2011 +0000 +++ b/xml/ru/GNUmakefile Sat Oct 22 04:48:15 2011 +0000 @@ -45,7 +45,7 @@ ru/docs/http/ngx_http_ssi_module \ ru/docs/http/ngx_http_ssl_module \ ru/docs/http/ngx_http_sub_module \ - ru/docs/http/ngx_http_upstream \ + ru/docs/http/ngx_http_upstream_module \ ru/docs/http/ngx_http_userid_module \ ru/docs/http/ngx_http_xslt_module \ diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/docs/http/ngx_http_fastcgi_module.xml --- a/xml/ru/docs/http/ngx_http_fastcgi_module.xml Fri Oct 21 21:16:08 2011 +0000 +++ b/xml/ru/docs/http/ngx_http_fastcgi_module.xml Sat Oct 22 04:48:15 2011 +0000 @@ -472,7 +472,7 @@ Если доменное имя резолвится в несколько адресов, то все они будут использоваться в режиме round-robin. И кроме того, адрес может быть -группой серверов. +группой серверов. diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/docs/http/ngx_http_memcached_module.xml --- a/xml/ru/docs/http/ngx_http_memcached_module.xml Fri Oct 21 21:16:08 2011 +0000 +++ b/xml/ru/docs/http/ngx_http_memcached_module.xml Sat Oct 22 04:48:15 2011 +0000 @@ -130,7 +130,7 @@ Если доменное имя резолвится в несколько адресов, то все они будут использоваться в режиме round-robin. И кроме того, адрес может быть -группой серверов. +группой серверов. diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/docs/http/ngx_http_proxy_module.xml --- a/xml/ru/docs/http/ngx_http_proxy_module.xml Fri Oct 21 21:16:08 2011 +0000 +++ b/xml/ru/docs/http/ngx_http_proxy_module.xml Sat Oct 22 04:48:15 2011 +0000 @@ -432,7 +432,7 @@ Если доменное имя резолвится в несколько адресов, то все они будут использоваться в режиме round-robin. И кроме того, адрес можно задать -группой серверов. +группой серверов. @@ -506,7 +506,7 @@ В этом случае имя сервера ищется среди описанных -групп серверов +групп серверов и если не найдено, то определяется с помощью resolver'а. diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/docs/http/ngx_http_upstream.xml --- a/xml/ru/docs/http/ngx_http_upstream.xml Fri Oct 21 21:16:08 2011 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,241 +0,0 @@ - - - - - - -
- - -Модуль позволяет описывать группы серверов, -которые могут использоваться в директивах -. - - -
- - -
- - - -upstream backend { - server backend1.example.com weight=5; - server backend2.example.com:8080; - server unix:/tmp/backend3; - - server backup1.example.com:8080 backup; - server backup2.example.com:8080 backup; -} - -server { - location / { - proxy_pass http://backend; - } -} - - - -
- - -
- - - - -upstream - - -Директива задаёт метод распределения запросов по серверам на основе -IP-адресов клиентов. В качестве ключа для хеширования используется сеть -класса C, в которой находится адрес клиента. -Метод гарантирует, что запросы клиента будут передаваться на один и тот же -сервер. Если же этот сервер будет считаться неработающим, то запросы этого -клиента будут передаваться на другой сервер. С большой долей вероятности -это также будет один и тот же сервер. - - - -Для серверов, использующих метод распределения ip_hash, нельзя задать вес. -Если один из серверов нужно убрать на некоторое время, то для сохранения -текущего хеширования IP-адресов клиентов этот сервер нужно пометить -параметром down. - - - -Пример конфигурации: - -upstream backend { - ip_hash; - - server backend1.example.com; - server backend2.example.com; - server backend3.example.com down; - server backend4.example.com; -} - - - - - - - -название [параметры] - -upstream - - -Директива задаёт имя и параметры сервера. -В качестве имени можно использовать доменное имя, адрес, порт или путь -unix-сокета. Если доменное имя резолвится в несколько адресов, то -используются все. - - - -weight=число — задаёт вес сервера, по умолчанию вес равен одному. - - - -max_fails=число — задаёт число неудачных попыток работы с сервером -в течение времени, заданного параметром fail_timeout, -после которых он считается неработающим также в течение времени -заданного параметром fail_timeout. -По умолчанию число попыток равно одной. -Нулевое значение запрещает учёт попыток. -Что считается неудачной попыткой, задаётся директивами -. -Состояние http_404 не считается неудачной попыткой. - - - -fail_timeout=время — задаёт - - - -время, в течение которого должно произойти заданное число неудачных -попыток работы с сервером для того, чтобы сервер считался неработающим; - - - -и время, в течение которого сервер будет считаться неработающим. - - - -По умолчанию время равно 10 секундам. - - - -backup — помечает сервер как запасной сервер. На него будут -передаваться запросы в случае, если не работают основные сервера. - - - -down — помечает сервер как постоянно неработающий, используется -совместно с директивой . - - - - - - -Пример конфигурации: - -upstream backend { - server backend1.example.com weight=5; - server 127.0.0.1:8080 max_fails=3 fail_timeout=30s; - server unix:/tmp/backend3; - - server backup1.example.com:8080 backup; -} - - - - - - - -название - -http - - -Директива описывает группу серверов. -Сервера могут слушать на разных портах, кроме того, можно одновременно -использовать сервера, слушающие на TCP и unix сокетах. - - - -Пример конфигурации: - -upstream backend { - server backend1.example.com weight=5; - server 127.0.0.1:8080 max_fails=3 fail_timeout=30s; - server unix:/tmp/backend3; -} - - - - -Запросы распределяются по серверам в режиме round-robin с учётом весов серверов. -В вышеприведённом примере каждые 7 семь запросов будут распределены так: -5 запросов на backend1.example.com и по одному запросу на второй и третий -сервера. -Если при попытке работы с сервером произошла ошибка, то запрос будет -передан следующему серверу и так до тех пор, пока не будут опробованы -все работающие сервера. Если не удастся получить успешный ответ -от всех серверов, то клиенту будет возвращён результат работы -с последним сервером. - - - - -
- - -
- - -Модуль ngx_http_upstream поддерживает следующие встроенные переменные: - - - -$upstream_addr — в переменной хранятся ip-адрес и порт сервера -или путь к unix-сокету. -Если при обработке запроса были сделаны обращения к нескольким серверам, -то их адреса разделяются запятой, например, -"192.168.1.1:80, 192.168.1.2:80, unix:/tmp/sock". -Если произошёл внутренний редирект от одной группы серверов на другую с помощью -"X-Accel-Redirect" или error_page, то эти группы серверов разделяются -двоеточием, например, -"192.168.1.1:80, 192.168.1.2:80, unix:/tmp/sock : 192.168.10.1:80, 192.168.10.2:80". - - - -$upstream_response_time — в переменной хранятся времена ответов серверов -в секундах с точностью до миллисекунд. -Несколько ответов также разделяются запятыми и двоеточиями. - - - -$upstream_status — в переменной хранятся коды ответов серверов. -Несколько ответов также разделяются запятыми и двоеточиями. - - - -$upstream_http_... — в переменных хранятся строки заголовков ответов -серверов, например, строка заголовка ответа "Server" доступна в переменной -$upstream_http_server. Необходимо иметь ввиду, что запоминаются только -строки последнего сервера. - - - - - -
- -
diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/docs/http/ngx_http_upstream_module.xml --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/xml/ru/docs/http/ngx_http_upstream_module.xml Sat Oct 22 04:48:15 2011 +0000 @@ -0,0 +1,241 @@ + + + + + + +
+ + +Модуль позволяет описывать группы серверов, +которые могут использоваться в директивах +. + + +
+ + +
+ + + +upstream backend { + server backend1.example.com weight=5; + server backend2.example.com:8080; + server unix:/tmp/backend3; + + server backup1.example.com:8080 backup; + server backup2.example.com:8080 backup; +} + +server { + location / { + proxy_pass http://backend; + } +} + + + +
+ + +
+ + + + +upstream + + +Директива задаёт метод распределения запросов по серверам на основе +IP-адресов клиентов. В качестве ключа для хеширования используется сеть +класса C, в которой находится адрес клиента. +Метод гарантирует, что запросы клиента будут передаваться на один и тот же +сервер. Если же этот сервер будет считаться неработающим, то запросы этого +клиента будут передаваться на другой сервер. С большой долей вероятности +это также будет один и тот же сервер. + + + +Для серверов, использующих метод распределения ip_hash, нельзя задать вес. +Если один из серверов нужно убрать на некоторое время, то для сохранения +текущего хеширования IP-адресов клиентов этот сервер нужно пометить +параметром down. + + + +Пример конфигурации: + +upstream backend { + ip_hash; + + server backend1.example.com; + server backend2.example.com; + server backend3.example.com down; + server backend4.example.com; +} + + + + + + + +название [параметры] + +upstream + + +Директива задаёт имя и параметры сервера. +В качестве имени можно использовать доменное имя, адрес, порт или путь +unix-сокета. Если доменное имя резолвится в несколько адресов, то +используются все. + + + +weight=число — задаёт вес сервера, по умолчанию вес равен одному. + + + +max_fails=число — задаёт число неудачных попыток работы с сервером +в течение времени, заданного параметром fail_timeout, +после которых он считается неработающим также в течение времени +заданного параметром fail_timeout. +По умолчанию число попыток равно одной. +Нулевое значение запрещает учёт попыток. +Что считается неудачной попыткой, задаётся директивами +. +Состояние http_404 не считается неудачной попыткой. + + + +fail_timeout=время — задаёт + + + +время, в течение которого должно произойти заданное число неудачных +попыток работы с сервером для того, чтобы сервер считался неработающим; + + + +и время, в течение которого сервер будет считаться неработающим. + + + +По умолчанию время равно 10 секундам. + + + +backup — помечает сервер как запасной сервер. На него будут +передаваться запросы в случае, если не работают основные сервера. + + + +down — помечает сервер как постоянно неработающий, используется +совместно с директивой . + + + + + + +Пример конфигурации: + +upstream backend { + server backend1.example.com weight=5; + server 127.0.0.1:8080 max_fails=3 fail_timeout=30s; + server unix:/tmp/backend3; + + server backup1.example.com:8080 backup; +} + + + + + + + +название + +http + + +Директива описывает группу серверов. +Сервера могут слушать на разных портах, кроме того, можно одновременно +использовать сервера, слушающие на TCP и unix сокетах. + + + +Пример конфигурации: + +upstream backend { + server backend1.example.com weight=5; + server 127.0.0.1:8080 max_fails=3 fail_timeout=30s; + server unix:/tmp/backend3; +} + + + + +Запросы распределяются по серверам в режиме round-robin с учётом весов серверов. +В вышеприведённом примере каждые 7 семь запросов будут распределены так: +5 запросов на backend1.example.com и по одному запросу на второй и третий +сервера. +Если при попытке работы с сервером произошла ошибка, то запрос будет +передан следующему серверу и так до тех пор, пока не будут опробованы +все работающие сервера. Если не удастся получить успешный ответ +от всех серверов, то клиенту будет возвращён результат работы +с последним сервером. + + + + +
+ + +
+ + +Модуль ngx_http_upstream_module поддерживает следующие встроенные переменные: + + + +$upstream_addr — в переменной хранятся ip-адрес и порт сервера +или путь к unix-сокету. +Если при обработке запроса были сделаны обращения к нескольким серверам, +то их адреса разделяются запятой, например, +"192.168.1.1:80, 192.168.1.2:80, unix:/tmp/sock". +Если произошёл внутренний редирект от одной группы серверов на другую с помощью +"X-Accel-Redirect" или error_page, то эти группы серверов разделяются +двоеточием, например, +"192.168.1.1:80, 192.168.1.2:80, unix:/tmp/sock : 192.168.10.1:80, 192.168.10.2:80". + + + +$upstream_response_time — в переменной хранятся времена ответов серверов +в секундах с точностью до миллисекунд. +Несколько ответов также разделяются запятыми и двоеточиями. + + + +$upstream_status — в переменной хранятся коды ответов серверов. +Несколько ответов также разделяются запятыми и двоеточиями. + + + +$upstream_http_... — в переменных хранятся строки заголовков ответов +серверов, например, строка заголовка ответа "Server" доступна в переменной +$upstream_http_server. Необходимо иметь ввиду, что запоминаются только +строки последнего сервера. + + + + + +
+ +
diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/docs/index.xml --- a/xml/ru/docs/index.xml Fri Oct 21 21:16:08 2011 +0000 +++ b/xml/ru/docs/index.xml Sat Oct 22 04:48:15 2011 +0000 @@ -93,8 +93,8 @@ - -ngx_http_upstream + +ngx_http_upstream_module diff -r 0991bf45cbb8 -r edf8c90f8085 xml/ru/index.xml --- a/xml/ru/index.xml Fri Oct 21 21:16:08 2011 +0000 +++ b/xml/ru/index.xml Sat Oct 22 04:48:15 2011 +0000 @@ -52,7 +52,7 @@ Акселерированное проксирование с кэшированием, -простое +простое распределение нагрузки и отказоустойчивость; @@ -62,7 +62,7 @@ uwsgi, SCGI и memcached серверов с кэшированием, -простое +простое распределение нагрузки и отказоустойчивость;