The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



Индекс форумов
Составление сообщения

Исходное сообщение
"Доступен Dqlite 1.0, распределённый вариант SQLite от компан..."
Отправлено opennews, 01-Сен-19 12:17 
Компания 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

 

Ваше сообщение
Имя*:
EMail:
Для отправки ответов на email укажите знак ! перед адресом, например, !user@host.ru (!! - не показывать email).
Более тонкая настройка отправки ответов производится в профиле зарегистрированного участника форума.
Заголовок*:
Сообщение*:
 
При общении не допускается: неуважительное отношение к собеседнику, хамство, унизительное обращение, ненормативная лексика, переход на личности, агрессивное поведение, обесценивание собеседника, провоцирование флейма голословными и заведомо ложными заявлениями. Не отвечайте на сообщения, явно нарушающие правила - удаляются не только сами нарушения, но и все ответы на них. Лог модерирования.



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру