Битва WEB-серверов. Часть 1 – оторванный от реальности HTTP:

В этой статье мы попробуем себя в реверс-инжиниринге, можно сказать. Мы заглянем своими грязными руками под капот каждого из веб-серверов, эксплуатируя их так, как никто бы никогда не эксплуатировал.

Этот тест — замер сферического коня в вакууме, не более чем данные, которые были получены, и мы теперь не знаем, что с ними делать.

99c9f31bcc5b4cc30305d5058d62b985.png


Методика


В качестве операционной системы для Nginx и Apache выступает Ubuntu 18.04 LTS, для IIS Windows Server Core 2019. Все операционные системы перед тестами получили последние обновления на состояние 04.12.2019.

Тесты проводились исключительно по HTTP. На каждом из веб-серверов крутилась одна и та же страница, бесплатный шаблон для Jekyll от Codrops. Ссылка. На каждом из веб-серверов было выключено сжатие gzip.

Тест пропускной способности проводился с Httpd-tools с аргументами:

ab -n 50000 -c 500 http://192.168.76.204:80/


На серверы устанавливался лимит в 10, 5 и 1 процент от ядра на 8, 4 и одном ядре. В качестве тестового стенда был компьютер с 9900K@5400 мгц, что означает, что сервер получивший ограничение в 10%, получает около 540 мгц на ядро.

Тест TTFB проводился при первой загрузке сервера и замерялся с помощью DevTools, после получения результата сервер выключался и откатывался на предыдущую контрольную точку, чтобы исключить появление любого рода кэшей.

Тестировщик и веб-сервер находились на одном и том же хосте и на одном и том же виртуальном свитче.

Чтобы сразу оценить дисковую подсистему, результаты бенчмарка ATTO и CrystalDIskMark, чтобы иметь понятие об узких местах.

Данные сняты с виртуальной машины:


Результаты:


TTFB:

bf5fe5c2bae34522885c9ae239675400.png


Средний TTFB у IIS меньше всех, 0,5 мс, против 1,4 мс у Apache и 4 мс у Nginx.

Throughput:

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

3002624d05781ec5c95950dcfc1daa5c.png


На графике представлено количество обращений тестировщика к веб-серверу и латентность. На графике видно, что NGINX отработал 98% всех обращений, отдав сайт за 20 мс и меньше. IIS как и Apache последние 5% из всех обращений отработали за 76 мс и 14 мс соответственно.

76a7eee7c32bffef084d3c5db1ff2ee8.png


751c139b1a6f21c2bb75d832412f4613.png


35c9ce9d7160f2778a10765755bbaf1e.png


На графике показано среднее время обработки одного запроса во время стресс теста.

Как можно заметить из графиков, IIS продул и Apache и Nginx, сильно замедляясь под высокой нагрузкой. 

IIS явно предпочел 4 ядра перед восьмью, показав меньшие задержки на четырёх, но так же не сильно одобрил и одно ядро.

NGINX прекрасно масштабируется на все 8 ядер, а для Apache, судя по всему, одноядерный сценарий кажется наилучшим выбором.

Масштабируемость:


Nginx:

Теперь рассмотрим масштабируемость по частоте и количеству ядер. 

6c702fbbcaa944c11b4c80c540ebdf16.png


Тесты с ограничением в 1% на 4 и 1 ядра Nginx не прошел, выйдя за 2000 запросов он обрывал соединение с тестировщиком.

Apache:

6819dbc8e46623e008cea01c415bec45.png


Apache как Nginx обработав 2500 запросов сдался и разорвал соединение. Apache не прошел тест на 8, 4 и 1 ядрах с лимитом в 1%, но помимо этого не прошел и тест на 5% ограничении на одном ядре, что хуже чем  Nginx

IIS:

e92c4ad79f28b4708e4bcc9f7fa90ec7.png


IIS по время тестов набрал гигантскую очередь из запросов, но обработал каждый из них. Судя по всему, в нем из коробки не установлены таймауты на обработку запроса.

47b1bcae54bd0ce3799c191fd436a410.png


На диаграмме представлено время, за которое был завершен тест. Были отброшены совсем абсурдные конфигурации тестирования. Из диаграммы видно, насколько IIS требователен к железу, и насколько прекрасен NGINX.

Масштабируемость от диска:


Nginx:

Теперь рассмотрим масштабируемость по частоте и количеству ядер и скорости диска. 

cd6425d9187b5a01be3e50644b8f8a86.png


На этот раз Nginx не прошел 4 теста, вместо двух.

Apache:

719da85499108111c2f156549efb13f7.png


Apache провалил одинаковое количество тестов, как и в прошлый раз.

IIS:

7e64a34014dd9b5c85e2524a35f79d3b.png


IIS показывает почти идентичный график, будто ограничений на диск и не было. В целом, графики у всех серверов не сильно изменились, а это значит, что каждый из них закэшировал статику в оперативную память и отдавал оттуда. Тут мы видим главное узкое место — сам веб-сервер.

Выводы на основе этого тестирования делать рано, мы еще не протестировали HTTPS, компрессию и HTTP/2 с живым сертификатом от Let«s Encrypt. Об этом расскажем в следующей статье.

fy_ygawz3qa9h28otrjzuvit7uw.jpeg

© Habrahabr.ru