Компания Canonical опубликовала (https://github.com/canonical/dqlite/releases/tag/v1.0.0) значительный выпуск проекта Dqlite 1.0 (https://dqlite.io/) (Distributed SQLite), развивающего совместимый с SQLite встраиваемый SQL-движок, поддерживающий репликацию данных, автоматическое восстановление после сбоев и обеспечение отказоустойчивости через разнесение обработчиков на несколько узлов. СУБД реализована в форме прикрепляемой к приложениям Си-библиотеки и распространяется (https://github.com/canonical/dqlite) под лицензией Apache 2.0 (оригинальный SQLite поставляется как общественное достояние). Доступны биндинги для языка Go (https://github.com/canonical/go-dqlite).
Библиотека является надстройкой над существующей кодовой базой SQLite, которая добавляет поддержку сетевого протокола для связывания между собой нескольких экземпляров приложения, запущенных на разных хостах. Собранное с Dqlite приложение может функционировать как самодостаточный отказоустойчивый кластер, не зависящий от внешних СУБД. На практике Dqlite используется компанией Canonical в системе управления контейнерами LXD (https://www.opennet.ru/opennews/art.shtml?num=44228). Среди областей применения библиотеки также упоминается создание отказоустойчивых устройств интернета-вещей и обработчиков в системах
Edge (https://www.opennet.ru/opennews/art.shtml?num=48372)-вычислений (https://www.opennet.ru/opennews/art.shtml?num=51077).
Для обеспечения непротиворечивости при репликации данных применяется метод достижения консенсуса на базе алгоритма Raft (https://raft.github.io/), который используется в таких проектах, как etcd, RethinkDB, CockroachDB и OpenDaylight. В Dqlite применяется собственная асинхронная реализация C-raft (https://github.com/canonical/raft), написанная на языке Си. Для мультиплексирования обработки соединений и организации запуска сопрограмм используются готовые библиотеки libuv (https://libuv.org/) и libco (https://github.com/canonical/libco).
По сравнению с похожим проектом rqlite (https://github.com/rqlite/rqlite), Dqlite обеспечивает полную поддержку транзакций, может связываться с любыми проектами на языке Си, позволяет использовать функцию time() и применяет репликацию на основе кадров вместо репликации на основе трансляции SQL-выражений.
Особенности Dqlite:
- Выполнение всех дисковых и сетевых операций в асинхронном режиме;
- Наличие тестового набора для подтверждения корректности данных;
- Низкое потребление памяти и эффективный обмен данным по сети;
- Постоянное хранение на диске БД и лога транзакций (c возможностью кэширования в памяти);
- Быстрое восстановление после сбоев;
- Стабильный CLI-клиент на языке Go, который можно использовать для инициализации БД, настройки репликации и подключения/отключения узлов;
- Поддержка архитектур ARM, X86, POWER и IBM Z;
- Реализация алгоритма Raft оптимизирована для минимизации задержек при фиксации транзакций.
URL: https://github.com/canonical/dqlite/releases
Новость: https://www.opennet.ru/opennews/art.shtml?num=51402