nginx
Nginx | |
---|---|
![]() логотип nginx | |
Тип | веб-сервер |
Автор | Игорь Сысоев и Коновалов, Максим[d][1] |
Разработчик | NGINX, Inc.[d] и Игорь Сысоев |
Написана на | Си[3] |
Операционная система | UNIX-подобные операционные системы и Microsoft Windows |
Первый выпуск | 4 октября 2004[2] |
Последняя версия | 1.17.6 (19 ноября 2019) |
Читаемые форматы файлов | PEM encoded certificate[d][4] и PEM encoded RSA private key[d][4] |
Лицензия | 2-пунктная лицензия BSD[d][5][6] |
Сайт | nginx.org |
![]() |
nginx (engine x — англ. Engine X; по-русски произносится как э́нгинкс[7] или э́нжин-и́кс[8]) — веб-сервер и почтовый прокси-сервер, работающий на Unix-подобных операционных системах (тестировалась сборка и работа на FreeBSD, OpenBSD, Linux, Solaris, Mac OS X, AIX и HP-UX). Начиная с версии 0.7.52 появилась экспериментальная[9] бинарная сборка под Microsoft Windows.
Игорь Сысоев начал разработку в 2002 году[10]. Осенью 2004 года вышел первый публично доступный релиз. С июля 2011 работа над nginx продолжается в рамках компании Nginx.
Содержание
Основные функции[править | править код]
nginx позиционируется производителем как простой, быстрый и надёжный сервер, не перегруженный функциями.
Применение nginx целесообразно прежде всего для статических веб-сайтов и как обратного прокси-сервера перед динамическими сайтами[источник не указан 2696 дней].
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 сервера выглядит следующим образом[11]:
- получить очередной дескриптор из kevent(2);
- прочитать данные из файла и записать в socket, используя либо write(2)/read(2), например, так[12]:
while
(
(
cnt = read
(
read_file_descriptor,
buffer,
block_size
),
write
(
socket_file_descriptor,
buffer,
count
) == cnt
)
)
byte_count += count;
- либо используя системный вызов sendfile(2), выполняющий те же действия, что приведённый выше код, но в пространстве ядра;
- перейти к шагу 1.
Конфигурация 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 на февраль 2018 года, число сайтов, обслуживаемых nginx, превышает 447 миллионов, что делает его третьим по популярности веб-сервером в мире. Доля среди активных сайтов — 21,13 %, что ставит nginx на второе место после веб-сервера Apache[13].
По данным W3Techs, nginx наиболее часто используется на высоконагруженных сайтах[14], занимая первое место по частоте использования среди 100 000 самых посещаемых сайтов в мире — больше половины из них работает на nginx.
По данным российского регистратора REG.RU, nginx является самым популярным веб-сервером доменных зон .ru[15], .рф[16] и .su[17], обслуживая более половины каждого сегмента.
NGINX — самый популярный веб-сервер в России с долей рынка 65,90 %[18].
Среди известных проектов, использующих nginx: Рамблер[19], Яндекс[20], Mail.ru, Хабрахабр[21], Живой Журнал[22], Avito.ru[23], Badoo[24], Ukr.net, Begun, Wordpress.com, SourceForge.net[25], ВКонтакте[26], Qiwi.com[27], Facebook, Groupon, Rutracker.org[28], Netflix[29], Instagram[30], Pinterest[31], Tumblr[32], Superjob.ru[33], HeadHunter[34], 2ГИС[35] и многие другие[13].
Компания Nginx[править | править код]
Nginx Inc. | |
---|---|
![]() | |
Тип | частная компания |
Основание | 2011 |
Расположение |
![]() |
Отрасль |
разработка программного обеспечения (МСОК: 6201 ) |
Продукция | Nginx, Nginx Plus |
Сайт | nginx.com |
![]() |
Для разработки коммерческих продуктов Игорь Сысоев создал в июле 2011 года компанию Nginx. Разработка ведётся в офисе, находящемся в Москве, для продаж создана американская «дочка» — Nginx Inc[36]. В феврале 2012 компания начала предоставлять коммерческий сервис для клиентов[37]. Были введены три пакета технической поддержки — Premium, Advanced и Essential. Эти пакеты включают в себя установку, повышение производительности, конфигурацию, сопровождение программного обеспечения, реализацию, содействие в проектировании и финальной оптимизации.
В декабре 2011 года компания привлекла $3 миллиона от пула инвесторов (в раунде лидировал фонд BV Capital[en]; соинвесторами выступили фонды Runa Capital и семейный фонд Майкла Делла MSD Capital[en][36][38].
В октябре 2013 компания привлекла ещё $10 миллионов. Ведущим инвестором выступил фонд New Enterprise Associates[en]; соинвесторами выступили все фонды предыдущего раунда, а также Аарон Леви, глава Box.com[39].
9 декабря 2014 было объявлено о привлечении дополнительных инвестиций в размере $20 миллионов. Возглавил раунд венчурный фонд New Enterprise Associates при участии фондов Index Ventures[en], Runa Capital, E.ventures (бывший BV Capital) и гендиректора Nginx Гуса Робертсона[40][41][42].
11 марта 2019 года объявлено, что компания F5 Networks[en] покупает NGINX. Сумма сделки оценивается приблизительно в 670 миллионов долларов.[43][44][45].
Примечания[править | править код]
- ↑ Maxim Konovalov - NGINX
- ↑ http://nginx.org/ru/CHANGES.ru
- ↑ The nginx Open Source Project on Open Hub: Languages Page — 2006.
- ↑ 1 2 Module ngx_http_ssl_module
- ↑ https://nginx.org/LICENSE
- ↑ The nginx Open Source Project on Open Hub: Licenses Page — 2006.
- ↑ Буква en:x в английском языке произносится как экс /ˈɛks/
- ↑ Лекция «Сравнительный анализ архитектур серверных интернет-приложений для высоких нагрузок», лектор: Игорь Сысоев.
- ↑ http://nginx.org/ru/docs/windows.html nginx под Windows
- ↑ На http://sysoev.ru/nginx/ можно прочитать: «Я начал разрабатывать nginx весной 2002 года…»
- ↑ Доклад Глеба Смирнова (glebius@freebsd.org), разработчика nginx и FreeBSD, на конференции «ruBSD 2014» 13 декабря 2014 года.
- ↑ FreeBSD 1.0, 1993 год. Код функции
send_data()
изsrc/libexec/ftpd/ftpd.c
. - ↑ 1 2 February 2018 Web Server Survey (англ.)
- ↑ Usage of web servers broken down by ranking (англ.)
- ↑ Веб-серверы зоны .RU
- ↑ Веб-серверы зоны .РФ
- ↑ Веб-серверы зоны .SU
- ↑ Статистика российского интернета runfo.ru . www.runfo.ru. Дата обращения 17 мая 2017.
- ↑ Web Technologies used by Rambler.ru (англ.)
- ↑ Web Technologies used by Yandex.ru (англ.)
- ↑ Web Technologies used by Habrahabr.ru (англ.)
- ↑ Web Technologies used by Livejournal.com (англ.)
- ↑ Web Technologies used by Avito.ru (англ.)
- ↑ Web Technologies used by Badoo.com (англ.)
- ↑ GET -ed http://sourceforge.net | grep Server
- ↑ Web Technologies used by Vk.com (англ.)
- ↑ Web Technologies used by Qiwi.com . w3techs.com. Дата обращения 20 мая 2016.
- ↑ Вкладка «Net» из Firebug’а
- ↑ Netflix — Appliance Software
- ↑ Web Technologies used by Instagram.com (англ.)
- ↑ Web Technologies used by Pinterest.com (англ.)
- ↑ Web Technologies used by Tumblr.com (англ.)
- ↑ Web Technologies used by Superjob.ru (англ.)
- ↑ Web Technologies used by Hh.ru (англ.)
- ↑ Web Technologies used by 2gis.ru (англ.)
- ↑ 1 2 Анастасия Голицына. Nginx получила от фондов $3 млн (англ.). Ведомости (11 October 2011). Дата обращения 19 октября 2014.
- ↑ NGINX начинает предлагать платные услуги своим клиентам (англ.)
- ↑ Natasha Starkell. Russian Nginx Raises $3 Million From International Investors (англ.). Techcrunch (11 October 2011). Дата обращения 19 октября 2014.
- ↑ Frederic Lardinois. Nginx Raises $10M Series B Round Led By NEA (англ.). Techcrunch (15 October 2013). Дата обращения 19 октября 2014.
- ↑ Мария Коломыченко. Nginx вышел на третий раунд . Коммерсант (9 декабря 2014). Дата обращения 9 декабря 2014.
- ↑ Frederic Lardinois. Nginx Raises $20M Series B1 Round To Drive International Expansion (англ.). Techcrunch (9 December 2014). Дата обращения 9 декабря 2014.
- ↑ Jordan Novet. Nginx gets $20M, because an open-source web server is just the beginning (англ.). VentureBeat (9 December 2014). Дата обращения 9 декабря 2014.
- ↑ F5 покупает NGINX
- ↑ NGINX to Join F5: Proud to Finish One Chapter and Excited to Start the Next
- ↑ F5 Acquires NGINX to Bridge NetOps & DevOps, Providing Customers with Consistent Application Services Across Every Environment
См. также[править | править код]
Ссылки[править | править код]
- Официальный сайт. (рус.)
- Английская версия. (англ.)
- Wiki-nginx (англ.)
- Лист рассылки nginx (рус.)
- Программное обеспечение по алфавиту
- Программное обеспечение, разработанное в 2004 году
- Производители программного обеспечения США
- Компании по алфавиту
- Компании, основанные в 2011 году
- Свободные веб-серверы
- Свободное серверное программное обеспечение
- Свободное программное обеспечение, написанное на Си
- Программное обеспечение с лицензией BSD