For faster navigation, this Iframe is preloading the Wikiwand page for HAProxy.

HAProxy

Материал из Википедии — свободной энциклопедии

HAProxy
Скриншот программы HAProxy
Автор Willy Tarreau
Разработчик HAProxy Technologies[вд]
Написана на C
Операционные системы Linux, FreeBSD, OpenBSD, Solaris (8/9/10), AIX (5.1-5.3)
Последняя версия 2.7.5 (17 марта 2023)
Репозиторий github.com/haproxy/hapro…
Лицензия GNU General Public License v2
Сайт haproxy.org

HAProxy — серверное программное обеспечение для обеспечения высокой доступности и балансировки нагрузки для TCP- и HTTP-приложений посредством распределения входящих запросов на несколько обслуживающих серверов.[1] Программа написана на C[2].

HAProxy используется в ряде высоконагруженных веб-сайтов, включая Twitter[3], Instagram[3] Github[4], Stack Overflow,[5] Reddit, Tumblr, DeviantArt, Avito и OpsWorks product из Amazon Web Services[6], W3C (W3C Validator)[3], а также является частью облачной платформы Red Hat OpenShift[7] и балансировщиком по умолчанию в облачной платформе OpenStack.

HAProxy является программой с открытым исходным кодом и распространяется в соответствии с GNU General Public License (GNU GPL v2).

Возможности

[править | править код]
  • Периодическая проверка доступности обслуживающих (back-end) серверов, на которые перенаправляются запросы пользователей;
  • Несколько алгоритмов определения доступности сервера: tcp-check, http-check, mysql-check;
  • Балансировка HTTP / HTTPS / TCP-запросов между «живыми» серверами;
  • Поддержка TLS SNI для различения HTTPS-обращений к разным сайтам;
  • Возможность закрепления определенных клиентов за конкретными обслуживающими серверами (stick-tables);
  • Поддержка: IPv6 и UNIX sockets, HTTP/1.1 сжатие (deflate, gzip, libslz), SSL-шифрование, полная поддержка постоянного HTTP-соединения;
  • Поддержка переменных, цитирования[неизвестный термин] блоков и Lua-скриптов в конфигурации сервера;
  • Веб-интерфейс с актуальным состоянием и статистикой работы программы;
  • Поддержка HTTP/2[8].

Производительность

[править | править код]

2007 год: Типичные 1U серверы оснащённые двухъядерным процессором Opteron или Xeon обычно достигали производительности от 15 000 до 40 000 запросов/сек и не имели проблем с обслуживанием потока до 2 Гбит/с под ОС Linux.[9]

2014 год: 1U серверы оснащённые Xeon E5 (2014 года) и 10 Гбит/с сетевой картой без проблем обрабатывают поток 40—60 Гбит/с, при этом подчёркивается, что ограничивающим фактором является пропускная способность сетевой карты.[10]

Даже на процессоре Intel Atom 1,6 ГГц (с пассивным воздушным охлаждением) HAProxy удалось обрабатывать поток до 1 ГБит/с.[10]

Расход памяти: 1 Гб ОЗУ хватает для обслуживания ~20 000—30 000 одновременных сессий.

Willy Tarreau[11] (один из основных разработчиков ядра Linux[12]) написал HAProxy в 2000 году и до сих пор занимается её разработкой.

В 2015 году, подводя итоги релиза HAProxy 1.6, Вилли отметил, что из более чем 1150 коммитов принятых в ветку 1.6, более 1/3 были сделаны сообществом.

Примечания

[править | править код]
  1. MySQL Load Balancing with HAProxy. Severalnines AB (2011). Дата обращения: 19 февраля 2013. Архивировано 8 февраля 2015 года.
  2. HAProxy on Freecode. Дата обращения: 5 апреля 2013. Архивировано 3 ноября 2017 года.
  3. 1 2 3 HAProxy: they use it! Дата обращения: 22 июня 2014. Архивировано 17 февраля 2014 года.
  4. список сайтов использующих HAProxy. Дата обращения: 22 июня 2014. Архивировано из оригинала 10 июня 2013 года.
  5. What it takes to run Stack Overflow. Дата обращения: 22 ноября 2013. Архивировано 11 ноября 2020 года.
  6. HAProxy layer - AWS Opsworks. Дата обращения: 5 апреля 2013. Архивировано 5 сентября 2015 года.
  7. OpenShift: How Scaling Works. Дата обращения: 22 сентября 2014. Архивировано 13 сентября 2014 года.
  8. May, 15th, 2015 : HTTP/2 is out! Дата обращения: 6 января 2016. Архивировано 13 января 2016 года.
  9. haproxy.org/#plat
  10. 1 2 haproxy.org/#perf
  11. Willy Tarreau: About me. Дата обращения: 5 апреля 2013. Архивировано 2 апреля 2013 года.
  12. ,LKML: Willy Tarreau: [ANNOUNCE] Linux 2.4.37.11. Дата обращения: 5 апреля 2013. Архивировано 15 июня 2012 года.
Для улучшения этой статьи желательно: Проверить достоверность указанной в статье информации. На странице обсуждения должны быть пояснения.После исправления проблемы исключите её из списка. Удалите шаблон, если устранены все недостатки.
{{bottomLinkPreText}} {{bottomLinkText}}
HAProxy
Listen to this article

This browser is not supported by Wikiwand :(
Wikiwand requires a browser with modern capabilities in order to provide you with the best reading experience.
Please download and use one of the following browsers:

This article was just edited, click to reload
This article has been deleted on Wikipedia (Why?)

Back to homepage

Please click Add in the dialog above
Please click Allow in the top-left corner,
then click Install Now in the dialog
Please click Open in the download dialog,
then click Install
Please click the "Downloads" icon in the Safari toolbar, open the first download in the list,
then click Install
{{::$root.activation.text}}

Install Wikiwand

Install on Chrome Install on Firefox
Don't forget to rate us

Tell your friends about Wikiwand!

Gmail Facebook Twitter Link

Enjoying Wikiwand?

Tell your friends and spread the love:
Share on Gmail Share on Facebook Share on Twitter Share on Buffer

Our magic isn't perfect

You can help our automatic cover photo selection by reporting an unsuitable photo.

This photo is visually disturbing This photo is not a good choice

Thank you for helping!


Your input will affect cover photo selection, along with input from other users.

X

Get ready for Wikiwand 2.0 🎉! the new version arrives on September 1st! Don't want to wait?