nginx

Материал из Википедии — свободной энциклопедии
Перейти к: навигация, поиск
nginx
Nginx.gif
Тип

Веб-сервер, почтовый прокси-сервер

Автор

Игорь Сысоев

Разработчик

NGINX, Inc.

Написана на

C

Операционная система

Unix‐подобные, Windows

Первый выпуск

4 октября 2004[1]

Последняя версия

1.6.0[2] (24 апреля 2014)

Тестовая версия

1.7.2[2] (17 июня 2014)

Состояние

активное

Лицензия

BSD-like[3], имеется коммерческая поддержка[4]

Сайт

http://nginx.org/

nginx (англ. engine x) (по-русски произносится как э́нжин-э́кс[5] или э́нжин-и́кс[6]) — веб-сервер и почтовый прокси-сервер, работающий на Unix-подобных операционных системах (тестировалась сборка и работа на FreeBSD, OpenBSD, Linux, Solaris, Mac OS X, AIX и HP-UX). Начиная с версии 0.7.52 появилась экспериментальная[7] бинарная сборка под Microsoft Windows.

Игорь Сысоев начал разработку в 2002-м году[8]. Осенью 2004 года вышел первый публично доступный релиз. По состоянию на 2014 год, поддержка и доработка nginx продолжается.

Основные функции[править | править вики-текст]

nginx — простой, быстрый и надёжный сервер, не перегруженный функциями. Применение nginx целесообразно прежде всего для статических веб-сайтов и как прокси-сервера перед динамическими сайтами.[источник не указан 729 дней]

HTTP-сервер[править | править вики-текст]

  • обслуживание статических запросов, индексных файлов, автоматическое создание списка файлов, кеш дескрипторов открытых файлов
  • акселерированное проксирование без кэширования, простое распределение нагрузки и отказоустойчивость
  • поддержка кеширования при акселерированном проксировании и FastCGI
  • акселерированная поддержка FastCGI и memcached серверов, простое распределение нагрузки и отказоустойчивость
  • модульность, фильтры, в том числе сжатие (gzip), byte-ranges (докачка), chunked ответы, HTTP-аутентификация, SSI-фильтр
  • несколько подзапросов на одной странице, обрабатываемые в SSI-фильтре через прокси или FastCGI, выполняются параллельно
  • поддержка SSL
  • поддержка PSGI, WSGI
  • экспериментальная поддержка встроенного Perl

SMTP/IMAP/POP3-прокси сервер[править | править вики-текст]

  • перенаправление пользователя на SMTP/IMAP/POP3-бэкенд с использованием внешнего HTTP-сервера аутентификации
  • простая аутентификация (LOGIN, USER/PASS)
  • поддержка SSL и STARTTLS

Архитектура[править | править вики-текст]

В nginx рабочие процессы обслуживают одновременно множество соединений, мультиплексируя их вызовами операционной системы select, epoll (Linux) и kqueue (FreeBSD). Рабочие процессы выполняют цикл обработки событий от дескрипторов (см. Событийно-ориентированное программирование). Полученные от клиента данные разбираются с помощью конечного автомата. Разобранный запрос последовательно обрабатывается цепочкой модулей, задаваемой конфигурацией. Ответ клиенту формируется в буферах, которые хранят данные либо в памяти, либо указывают на отрезок файла. Буферы объединяются в цепочки, определяющие последовательность, в которой данные будут переданы клиенту. Если операционная система поддерживает эффективные операции ввода-вывода, такие как writev и sendfile, то nginx применяет их по возможности.

Конфигурация HTTP-сервера nginx разделяется на виртуальные серверы (директива server). Виртуальные серверы разделяются на location’ы (location). Для виртуального сервера возможно задать адреса и порты, на которых будут приниматься соединения, а также имена, которые могут включать * для обозначения произвольной последовательности в первой и последней части, либо задаваться регулярным выражением.

location’ы могут задаваться точным URI, частью URI, либо регулярным выражением. location’ы могут быть сконфигурированы для обслуживания запросов из статического файла, проксирования на fastcgi/memcached сервер.

Для эффективного управления памятью nginx использует пулы. Пул — это последовательность предварительно выделенных блоков динамической памяти. Длина блока варьируется от 1 до 16 килобайт. Изначально под пул выделяется только один блок. Блок разделяется на занятую область и незанятую. Выделение мелких объектов выполняется путём продвижения указателя на незанятую область с учётом выравнивания. Если незанятой области во всех блоках не хватает для выделения нового объекта, то выделяется новый блок. Если размер выделяемого объекта превышает значение константы NGX_MAX_ALLOC_FROM_POOL, либо длину блока, то он полностью выделяется из кучи.

Таким образом, мелкие объекты выделяются очень быстро и имеют накладные расходы только на выравнивание.

nginx содержит модуль географической классификации клиентов по IP-адресу. В его основу входит база данных соответствия IP-адресов географическому региону, представленная в виде Radix tree (сжатое префиксное дерево или сжатый бор) в оперативной памяти. nginx предварительно распределяет первые несколько уровней дерева, таким образом, чтобы они занимали ровно 1 страницу памяти. Это гарантирует, что при поиске IP-адреса для первых нескольких узлов при трансляции адреса всегда найдётся запись в TLB.

Популярность[править | править вики-текст]

По данным Netcraft на февраль 2014 года, число сайтов, обслуживаемых nginx, превышает 138 миллионов[9], что делает его третьим по популярности веб-сервером в мире. При этом, процент активных сайтов, использующих nginx, составляет 13,46 % от общего количества активных сайтов, что делает nginx вторым в мире по популярности веб-сервером среди активных сайтов, уступая лишь веб-серверу Apache.

По данным W3Techs, nginx наиболее часто используется на высоконагруженных сайтах[10], занимая первое место по частоте использования среди 1000 самых посещаемых сайтов в мире — больше трети таких сайтов работает на nginx.

По данным российского регистратора REG.RU, nginx является самым популярным веб-сервером доменных зон .ru[11], .рф[12] и .su[13], обслуживая более половины каждого сегмента.

Среди известных проектов, использующих nginx: Рамблер[14], Яндекс[15], Mail.ru, Хабрахабр[16], Живой Журнал[17], Avito.ru[18], Badoo[19], Ukr.net, Begun, Wordpress.com, SourceForge.net[20], ВКонтакте[21], Facebook, Groupon, Diary.ru, Rutracker.org[22], Netflix[23], Instagram[24], Pinterest[25], Tumblr[26], Superjob.ru[27], HeadHunter[28], 2ГИС[29], и многие другие[9].

В связи с растущей популярностью руководство проекта nginx решило начать предлагать коммерческий сервис для своих клиентов[30]. Для этого были введены три пакета технической поддержки — Premium, Advanced и Essential. Эти пакеты включают в себя установку, повышение производительности, конфигурацию, сопровождение программного обеспечения, реализацию, содействие в проектировании и финальной оптимизации.

Примечания[править | править вики-текст]

  1. Лог изменений
  2. 1 2 nginx news
  3. Лицензия. Архивировано из первоисточника 7 февраля 2012.
  4. Commercial support
  5. Буква en:x в английском языке произносится как экс /ˈɛks/
  6. Лекция «Сравнительный анализ архитектур серверных интернет-приложений для высоких нагрузок», лектор: Игорь Сысоев.
  7. http://nginx.org/ru/docs/windows.html nginx под Windows
  8. На http://sysoev.ru/nginx/ можно прочитать: «Я начал разрабатывать nginx весной 2002 года…»
  9. 1 2 February 2014 Web Server Survey (англ.)
  10. Usage of web servers broken down by ranking (англ.)
  11. Веб-серверы зоны .RU
  12. Веб-серверы зоны .РФ
  13. Веб-серверы зоны .SU
  14. Web Technologies used by Rambler.ru (англ.)
  15. Web Technologies used by Yandex.ru (англ.)
  16. Web Technologies used by Habrahabr.ru (англ.)
  17. Web Technologies used by Livejournal.com (англ.)
  18. Web Technologies used by Avito.ru (англ.)
  19. Web Technologies used by Badoo.com (англ.)
  20. GET -ed http://sourceforge.net | grep Server
  21. Web Technologies used by Vk.com (англ.)
  22. Вкладка «Net» из Firebug’а
  23. https://signup.netflix.com/openconnect/software
  24. Web Technologies used by Instagram.com (англ.)
  25. Web Technologies used by Pinterest.com (англ.)
  26. Web Technologies used by Tumblr.com (англ.)
  27. Web Technologies used by Superjob.ru (англ.)
  28. Web Technologies used by Hh.ru (англ.)
  29. Web Technologies used by 2gis.ru (англ.)
  30. NGINX начинает предлагать платные услуги своим клиентам (англ.)

См. также[править | править вики-текст]

Ссылки[править | править вики-текст]