Hoʻokuʻu ʻia версия 0.9.1 библиотеки libmdbx (MDBX) с реализацией высокопроизводительной, компактной встраиваемой базы данных класса ключ-значение. Код libmdbx распространяется под лицензией OpenLDAP Public License.
Текущая версия является компромиссом между намерением выпустить долговременную стабильную версию 1.0 с полноценной поддержкой C++ и нежеланием откладывать релизы из-за неготовности к заморозке нового C++ API. Представленный релиз является результатом 9 месяцев работы направленной на стабилизацию библиотеки и повышения удобства её использования, а также включает предварительную версию C++ API.
Библиотека libmdbx является не просто «форком», а кардинально переработанным потомком LMDB — transactional embedded DBMS of the “key-value” class based on lāʻau B+ me kaʻole hoʻopaʻa paʻa, которая позволяет многопоточным процессам конкурентно и эффективно работать с локально-разделяемой (не сетевой) БД без выделенного серверного процесса. Libmdbx принципиально hoʻonui возможности своего прародителя, одновременно устраняя, либо смягчая недостатки. При этом, по убеждению разработчиков, libmdbx немного быстрее и существенно надежнее LMDB.
libmdbx предлагает ʻĀKIKA, строгую сериализацию изменений и неблокирующее чтение с линейным масштабированием по ядрам CPU. Результаты тестирования производительности (отправка параллельных запросов на чтение/поиск в 1-2-4-8 потоках на CPU i7-4600U c 2-я физическими ядрами в режиме 4-х потоков HyperThread):
ʻO nā ʻokoʻa nui loa ma waena o MDBX a me LMDB:
Принципиально больше внимания уделяется качеству кода, «непадучести» API, тестированию и автоматическим проверкам.
ʻOi aku ka mana i ka wā o ka hana, mai ka nānā ʻana i nā ʻāpana a i ka loiloi kūloko o nā hale waihona.
Auto-compactification a me ka hooponopono ana i ka nui o ka waihona.
Hoʻokahi waihona waihona no nā hui 32-bit a me 64-bit.
Ka manaʻo o ka laʻana puke ma nā pae (manaʻo noiʻi laulā).
Поддержка ключей вдвое большей длины и выбираемый пользователем размер страницы БД.
Утилита проверки целостности структуры БД с некоторыми возможностями восстановления.
Основные новшества и доработки после nuhou mua с представлением версии 0.5 в январе 2020:
Для оперативной поддержки и ответов на вопросы создана открытая группа в Телеграм.
Устранено более десятка ошибок и недочетов (см. hoʻololi log).
Исправлена масса опечаток и орфографических ошибок, множественные косметические улучшения.
Оформлена встроенная документация в формате Doxygen и автоматическая генерация Online документации.
Обеспечено автоматическое формирование архивов с амальгамированными исходными текстами.
Добавлена поддержка подготовки транзакций и курсоров, пользовательских контекстов для транзакций и курсоров.
Реализованы дополнительные методы контроля ссылочной целостности в MVCC-снимках B+tree.
Добавлена поддержка проверки MVCC-снимка БД, доступного через любую мета-страницу с возможностью переключения для восстановления.
Реализована поддержка повторного открытия БД из одного процесса в целях тестирования и т.п.
Реализована автоматическая обработка опции MDBX_NOSUBDIR при открытии БД.
Добавлены функции формирования целочисленных ключей из значений плавающей точки и «универсальных» чисел JavaScript.
Суммарно внесено 430 изменений затронувших 93 файла, добавлено более 25 тысяч строк, более 8.5 тысяч строк удалено.
Последующая разработка libmdbx будет сосредоточена на формировании финального C++ API, дальнейшей стабилизации базового кода, повышению удобства использования библиотеки, а также формирования пакетов для популярных дистрибутивов Linux. Из предполагаемых доработок стоит отметить поддержку ключей в формате MessagePack.