view xml/ru/docs/windows.xml @ 3076:be1ef1d56e96

Updated Windows archive names.
author Maxim Dounin <mdounin@mdounin.ru>
date Tue, 09 Apr 2024 18:20:21 +0300
parents 4795c2ae5066
children
line wrap: on
line source

<!--
  Copyright (C) Igor Sysoev
  Copyright (C) Nginx, Inc.
  -->

<!DOCTYPE article SYSTEM "../../../dtd/article.dtd">

<article name="freenginx под Windows"
         link="/ru/docs/windows.html"
         lang="ru"
         rev="5">

<section>

<para>
Версия freenginx под Windows использует “родной” Win32 API (не эмуляцию Cygwin).
В настоящий момент в качестве методов обработки соединений используются
<c-func>select</c-func> и <c-func>poll</c-func> (1.15.9),
поэтому не стоит ожидать высокой производительности и масштабируемости.
В силу этого и ряда других известных проблем версия freenginx под Windows
рассматривается пока как <i>бета</i>-версия.
На данный момент в ней доступна практически вся функциональность, что и
в версии nginx под UNIX, за исключением
XSLT-фильтра, фильтра изображений, модуля GeoIP и встроенного языка Perl.
</para>

<para>
Чтобы установить freenginx/Windows, <link doc="../download.xml">скачайте</link>
дистрибутив последней основной версии (<mainline_version/>),
поскольку основная ветвь nginx содержит все известные исправления.
Затем распакуйте дистрибутив, перейдите в каталог
freenginx-<mainline_version/>
и запустите <command>nginx</command>.
Вот пример для корневого каталога на диске C:

<programlisting>
cd c:\
unzip freenginx-<mainline_version/>.zip
cd freenginx-<mainline_version/>
start nginx
</programlisting>

Чтобы увидеть процессы freenginx, запустите утилиту командной строки
<command>tasklist</command>:

<programlisting>
C:\nginx-<mainline_version/>&gt;tasklist /fi "imagename eq nginx.exe"

Image Name           PID Session Name     Session#    Mem Usage
=============== ======== ============== ========== ============
nginx.exe            652 Console                 0      2 780 K
nginx.exe           1332 Console                 0      3 112 K
</programlisting>

Один из процессов главный, другой&mdash;рабочий.
Если nginx не запускается, нужно искать причину в
в файле лога ошибок <path>logs\error.log</path>.
Если же лог-файл не создался, то причину этого следует искать
в Windows Event Log.
Если вместо ожидаемой страницы выводится страница с ошибкой, нужно также
искать причины ошибки в файле <path>logs\error.log</path>.
</para>

<para>
freenginx/Windows использует каталог, в котором он был запущен, в качестве
префикса для относительных путей в конфигурации.
В вышеприведённом примере префиксом является
<path>C:\freenginx-<mainline_version/>\</path>.
Пути в конфигурационном файле должны задаваться в UNIX-стиле с использованием
прямых слэшей:

<programlisting>
access_log   logs/site.log;
root         C:/web/html;
</programlisting>
</para>

<para>
freenginx/Windows работает как стандартное консольное приложение (не сервис)
и управляется при помощи следующих команд:

<table note="yes">

<tr>
<td width="20%">nginx -s stop</td>
<td>быстрое завершение</td>
</tr>

<tr>
<td>nginx -s quit</td>
<td>плавное завершение</td>
</tr>

<tr>
<td>nginx -s reload</td>
<td>
изменение конфигурации,
запуск новых рабочих процессов с новой конфигурацией,
плавное завершение старых рабочих процессов
</td>
</tr>

<tr>
<td>nginx -s reopen</td>
<td>переоткрытие лог-файлов</td>
</tr>

</table>
</para>

</section>

<section id="known_issues"
        name="Известные проблемы">

<list type="bullet">

<listitem>
Хоть и возможен запуск нескольких рабочих процессов, только один из них
реально работает.
</listitem>

<listitem>
Проксирование по UDP не поддерживается.
</listitem>

</list>

</section>

<section id="possible_future_enhancements"
        name="Возможные усовершенствования в будущем">

<list type="bullet">

<listitem>
Запуск в виде сервиса.
</listitem>

<listitem>
Использование портов завершения ввода-вывода (I/O completion ports)
в качестве метода обработки соединений.
</listitem>

<listitem>
Использование нескольких рабочих нитей внутри одного рабочего процесса.
</listitem>

</list>

</section>

</article>