Corosync
Corosync (Corosync Cluster Engine) — проект с открытым исходным кодом, реализующий систему группового общения для отказоустойчивых кластеров. Является развитием проекта OpenAIS и опубликован в соответствии с модифицированной лицензией BSD.
Общие сведения
| Corosync | |
|---|---|
| Тип | Система группового общения для отказоустойчивых кластеров |
| Разработчик | The Corosync Development Community |
| Написана на | Си |
| Операционная система | Кроссплатформенное программное обеспечение |
| Первый выпуск | январь 2008[1] |
| Последняя версия | 3.1.6[2] (15 ноября 2021) |
| Репозиторий | github.com/corosync/coro… |
| Лицензия | "модифицированная" BSD |
| Сайт | corosync.github.io/corosync/ |
Особенности
Проект предоставляет четыре набора API для языка Си:
- «Закрытая группа процессов» (англ. Closed Process Group — CPG) — модель взаимодействия, реализующая виртуальную синхронизацию, которая гарантирует, что процессы на узлах кластера получат одинаковые сообщения в одинаковом порядке.
- «Простой менеджер доступности» (англ. Simple Availability Manager — SAM), отслеживающий состояния приложений и позволяющий их перезапускать после сбоя.
- «База данных конфигурации» (англ. Configuration database — confdb) в оперативной памяти, позволяющая получать конфигурацию и статистику Corosync, менять конфигурацию и получать уведомления об её изменениях.
- «Кворум» (англ. quorum) — система, оповещающая приложения о том, достигнут кворум (необходимое минимальное количество активных узлов кластера) или нет.
Программное обеспечение предназначено для работы в сетях UDP/IP и InfiniBand.
Архитектура
Программное обеспечение создано как исполняемые бинарные файлы, использующие клиент-серверную модель взаимодействия между библиотеками и сервисными инструментами. Модули, называемые сервисными инструментами, загружаются в Corosync и используют сервисы, предоставляемые внутренним API Corosync.
Сервисы, предоставляемые внутренним API Corosync:
- Реализация протокола «Упорядочивание и членство в одиночном кольце связи» (англ. Totem Single Ring Ordering and Membership)[3], обеспечивающего расширенную модель виртуальной синхронизации[4] сообщений.
- Coroipc — высокопроизводительная система межпроцессного взаимодействия через разделяемую память.[5]
- Объектная база данных, реализуемая через хранение в оперативной памяти (англ. in-memory database).
- Системы маршрутизации сетевых и межпроцессных сообщений через сервисные инструменты.
История
Проект был анонсирован в июле 2008 года на конференции Linux Symposium в Оттаве[1]. Исходный код проекта OpenAIS был реорганизован так, что инфраструктурные компоненты были помещены в Corosync, а API SA Forum остался в OpenAIS.
Во второй версии corosync (2012) изменена система кворума, ставшая составной частью демона[6], и отключена поддержка сторонних дополнений. Corosync 2 доступен с Fedora 17 и RHEL 7[7].
Примечания
Ссылки
- corosync.github.io/corosync/ — официальный сайт Corosync
- Andrew Beekhof, Pacemaker 1.1 Clusters from Scratch Архивная копия от 24 сентября 2016 на Wayback Machine, 2009-2015