Apache ZooKeeper - Apache ZooKeeper
Разработчики) | Фонд программного обеспечения Apache |
---|---|
Стабильный выпуск | 3.6.1 / 30 апреля 2020 г.[1] |
Репозиторий | Репозиторий ZooKeeper |
Написано в | Ява |
Операционная система | Кроссплатформенность |
Тип | Распределенных вычислений |
Лицензия | Лицензия Apache 2.0 |
Интернет сайт | работник зоопарка |
Apache ZooKeeper это программный проект Фонд программного обеспечения Apache. По сути, это служба за распределенные системы предлагая иерархический хранилище ключей и значений, который используется для предоставления распределенного служба конфигурации, служба синхронизации, и реестр имен для больших распределенных систем (см. Сценарии использования ).[2] ZooKeeper был подпроектом Hadoop но сейчас проект верхнего уровня Apache согласно своему праву.
Обзор
ZooKeeper's архитектура поддерживает высокая доступность через избыточные услуги. Таким образом, клиенты могут спросить другого лидера ZooKeeper, если первый не отвечает. Узлы ZooKeeper хранят свои данные в иерархическом пространстве имен, во многом как файловая система или дерево структура данных. Клиенты могут читать и записывать на узлы и, таким образом, иметь общую службу конфигурации. ZooKeeper можно рассматривать как атомная трансляция система, через которую обновления полностью заказанный. Протокол ZooKeeper Atomic Broadcast (ZAB) является ядром системы.[3]
ZooKeeper используется компаниями, в том числе Yelp, Rackspace, Yahoo!,[4] Одноклассники, Reddit,[5] NetApp SolidFire,[6] Facebook,[7] Twitter[8] и eBay а также Открытый исходный код поиск на предприятии такие системы, как Solr.[9]
ZooKeeper создан по образцу сервиса блокировки Google Chubby.[10][11] и изначально был разработан в Yahoo! для оптимизации процессов, выполняемых в кластерах больших данных, путем сохранения статуса в локальных файлах журнала на серверах ZooKeeper. Эти серверы связываются с клиентскими машинами, чтобы предоставить им информацию. ZooKeeper был разработан для исправления ошибок, возникающих при развертывании распределенных приложений для работы с большими данными.
Некоторые из основных функций Apache ZooKeeper:
- Надежная система: эта система очень надежна, так как продолжает работать даже при выходе из строя узла.
- Простая архитектура: архитектура ZooKeeper довольно проста, так как существует разделяемое иерархическое пространство имен, которое помогает координировать процессы.
- Быстрая обработка: ZooKeeper особенно быстро работает в рабочих нагрузках с преобладанием чтения (т. Е. Рабочих нагрузках, в которых чтение гораздо более распространено, чем запись).
- Масштабируемость: производительность ZooKeeper может быть улучшена путем добавления узлов.
Архитектура
Некоторые общие термины, касающиеся архитектуры ZooKeeper:
- Узел: системы, установленные в кластере.
- ZNode: узлы, статус которых обновляется другими узлами в кластере.
- Клиентские приложения: инструменты, которые взаимодействуют с распределенными приложениями.
- Серверные приложения: позволяет клиентским приложениям взаимодействовать с помощью общего интерфейса.
Сервисы в кластере реплицируются и хранятся на наборе серверов (называемых «ансамблем»), каждый из которых поддерживает базу данных в памяти, содержащую все дерево данных состояния, а также журнал транзакций и постоянно хранимые моментальные снимки. К серверу могут подключаться несколько клиентских приложений, и каждый клиент поддерживает TCP-соединение, через которое он отправляет запросы и контрольные сигналы, а также получает ответы и отслеживает события для мониторинга.[12]
Сценарии использования
Типичные варианты использования ZooKeeper:
- Служба именования
- Управление конфигурацией
- Синхронизация данных
- Выборы лидера
- Очередь сообщений
- Система оповещения
Клиентские библиотеки
В дополнение к клиентским библиотекам, включенным в дистрибутив ZooKeeper, доступен ряд сторонних библиотек, таких как Apache Curator и Kazoo, которые упрощают использование ZooKeeper, добавляют дополнительные функции, дополнительные языки программирования и т. Д.
Проекты Apache с использованием ZooKeeper
- Apache Hadoop
- Apache Accumulo
- Apache HBase
- Apache Hive
- Апач Кафка
- Apache Solr
- Apache Spark
- Apache NiFi
- Апач Друид
Смотрите также
Рекомендации
- ^ "Apache ZooKeeper - Выпуски". Получено 17 мая 2020.
- ^ «Индекс - Apache ZooKeeper - Фонд программного обеспечения Apache». cwiki.apache.org. Получено 2016-08-26.
- ^ "Обзор Zookeeper".
- ^ "ZooKeeper / Powered By". Архивировано из оригинал на 2013-12-09. Получено 2012-01-25.
- ^ «Почему Reddit не работал 11 августа».
- ^ «5 серьезных проблем DaaS и способы их решения | Новости NetApp». Отдел новостей NetApp. 2016-06-20. Получено 2017-05-24.[постоянная мертвая ссылка ]
- ^ «Распространение с учетом местоположения: масштабная настройка серверов». Код Facebook. 2018-07-19. Получено 2018-07-20.
- ^ "ZooKeeper в Твиттере". Технический блог Twitter. 2018-10-11. Получено 2018-12-08.
- ^ "SolrCloud".
- ^ Берроуз, Майк (2006). «Служба блокировки Chubby для слабосвязанных распределенных систем». 7-й симпозиум USENIX по разработке и внедрению операционных систем (OSDI).
- ^ Чандра, Тушар Дипак; Гриземер, Роберт; Редстоун, Джошуа (2007). "Paxos Made Live - инженерная перспектива (приглашенный доклад 2006 г.)". Google Research. Получено 2020-03-03.
- ^ "Работник зоопарка".