Используйте теги для того, чтобы помечать важные точки в истории изменений (например, релизы)
  • v0.14.0
    Технический тэг, отмечающий начало ветки `0.14` с новым функционалом и изменением API.
    
  • v0.13.3
    v0.13.3 "Королёв" (Korolev).
    
    Поддерживающий выпуск с исправлением обнаруженных ошибок и устранением недочетов
    в день рождения и в память об [Серге́е Па́вловиче Королёве](https://ru.wikipedia.org/wiki/Королёв,_Сергей_Павлович),
    советском учёном и Главном конструкторе ракетно-космических систем.
    
    За перечнем доработок и изменений обращайтесь к [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    git diff' stat: 67 files changed, 3514 insertions(+), 3004 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.13.2
    v0.13.2 "Прошлогодний Снег" (Last Year's Snow).
    
    Поддерживающий выпуск с исправлением обнаруженных ошибок и устранением недочетов
    в день рождения и в память об [Алекса́ндре Миха́йловиче Тата́рском](https://ru.wikipedia.org/wiki/Татарский,_Александр_Михайлович),
    российском режиссёре-мультипликаторе, создавшем такие знаменитые мультфильмы как "Падал прошлогодний снег",
    "Пластилиновая ворона", заставку "Спокойной ночи, малыши!" и многие другие шедевры нашего детства.
    
    За перечнем доработок и изменений обращайтесь к [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    git diff' stat: 151 files changed, 10647 insertions(+), 14952 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.12
    v0.12.12 "Доллежаль".
    
    Поддерживающий выпуск с исправлением обнаруженных ошибок и устранением недочетов,
    в память о советском ученом-энергетике Николае Антоновиче Доллежаль в день 125-летия со дня его рождения.
    
    Это последний выпуск куста стабильных версий 0.12.x, спустя более двух
    лет после выпуска 0.12.1. Последующие выпуски 0.12.x будут формироваться
    только в случае существенных проблем/ошибок, вероятность чего близка к
    нулю. Для всех проектов находящихся в стадии активной разраборки
    рекомендуется использовать ветку `master`.
    
    Значимые исправления:
    ---------------------
    
     - Исправление упущенного `TXN_END_EOTDONE` при сбое старта читающей транзакции.
       Упомянутый флажок отсутствовал в пути разрушения транзакции при ошибке
       её запуска. Из-за чего делалась попытка разрушить курсоры, что приводило
       к падению **отладочных сборок**, так как в них соответствующий массив
       намеренно заполнен некорректными указателями.
    
     - Устранение возможности `SIGSEGV` внутри `coherency_check()` после
       изменения геометрии другим процессом с увеличением верхнего размера БД
       и увеличением БД больше предыдущего лимита.
    
     - Доработка `mdbx_close_dbi()` для возврата ошибки при попытке закрыть
       dbi-дескриптор таблицы, созданной и/или измененной в ещё выполняющейся
       транзакции. Такое преждевременное закрытие дескриптора является неверным
       использованием API и нарушением контракта/предусловий сформулированных
       в описании `mdbx_close_dbi()`. Однако, вместо возврата ошибки
       выполнялось некорректное закрытие дескриптора, что могло приводить к
       созданию таблицы с пустым именем, утечки страниц БД и/или нарушению
       структуры b-tree (неверной ссылкой на корень таблицы).
       Добавлен соответствующий тест `extra/early_close_dbi`.
    
    Более подробная информация и история предыдущих выпусков доступна в [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    git diff' stat: 6 commits, 5 files changed, 239 insertions(+), 6 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.13.1
    v0.13.1 "РДС-1"
    
    Новая версия со сменой лицензии, существенным расширением API,
    добавлением функционала и внутренними переработками. В том числе,
    с незначительным нарушением обратной совместимости API библиотеки.
    
    Список нововведений, доработок и изменений слишком велик для размещения
    здесь, но вся информация есть в файле
    [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    ```
    git diff' stat: 157 files changed, 41949 insertions(+), 33741 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    ```
    
  • v0.12.11
    v0.12.11 "Лиза и Соня"
    
    Поддерживающий выпуск с исправлением обнаруженных ошибок и устранением недочетов,
    в память об убитых в Крыму девочках 2 и 9 лет.
    
    Лиза и Соня погибли 23 Июня 2024 на глазах у родителей, в результате
    удара по общественному городскому пляжу ракетами ATACMS с кассетными
    боеприпасами. Всего пострадало более 150 граждан России, в том числе 27
    детей. Ракеты были выпущенными украинскими бандеровцами/фашистами, но
    полетные задания формировались и загружались военными США, а управление
    и наведение ATACAMS невозможно без использования орбитальной группировки
    военных спутников США.
    
    Основные исправления:
    ---------------------
    
     - Исправление для ОС Windows нарезки `FILE_SEGMENT_ELEMENT`.
       Похоже что был потерян коммит входе работы над оптимизацией пути записи
       на диск в ОС Windows. В текущем понимании, вероятность проявления ошибки
       достаточно низкая, так как выявлена она была синтетическими тестами в
       ходе других доработок, а соответствующих сообщений/жалоб не поступало. К
       повреждению БД ошибка не приводила, так как сбой происходил до записи
       данных с возвратом `ERROR_INVALID_PARAMETER` из системного вызова, т.е.
       либо ошибка не проявлялась, либо транзакция не фиксировалась.
    
     - Устранение вероятности `SIGSEGV` при включении логирования
       уровня `MDBX_LOG_TRACE` в отладочных сборках.
    
     - Исправление генерации исключения `key_exists` в C++ API.
    
     - Исправление обработки курсоров, открытых в родительских транзакциях и
       закрытых до завершения вложенных транзакций. В описанной ситуации
       закрытые курсоры "воскрешались", что приводило к утечке памяти
       выделенной под такие курсоры.
    
     - Костыль для MSVC ARM/ARM64 для предотвращения ICE (Internal Compiler Error).
    
     - Устранение `MDBX_EINVAL` для случая вызова `mdbx_env_remove(".")`.
    
     - Исправление инверсии bool-результата `env::remove()`в C++ API.
    
    Более подробная информация в [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    git diff' stat: 29 commits, 14 files changed, 379 insertions(+), 151 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.13.0
    Не выпуск, а технический тэг для маркирования новой ветки `0.13.x` c развитием API.
  • v0.12.10
    v0.12.10 "СЭМ"
    
    Поддерживающий выпуск с исправлением обнаруженных ошибок и устранением недочетов
    в память Героя России гвардии майора Дмитрия Семёнова с позывным "СЭМ".
    
    Значимые исправления и доработки:
    ---------------------------------
    
     - Устранение унаследованной от LMDB ошибки приводящей к повреждению БД при использовании `MDBX_DUPFIXED`.
    
     - Исправление ложной ошибки `MDBX_CORRUPTED (-30796)` в сценарии работы
       в режиме `MDBX_DUPFIXED` и нечетной длинной мульти-значений.
    
     - Исправление недочета корректировки сопутствующих курсоров при разделении страницы
       по сценарию добавления пустой страницы слева.
    
     - Доработка `rebalance()` ради уменьшения WAF.
    
     - Исправление assert-проверки внутри `check_txn()` для случая завершенных транзакций в режиме `MDBX_NO_TLS`.
       Последствий ошибки, кроме срабатывания assert-проверки в отладочных сборках, нет.
    
     - Устранение ошибки при открытии БД на файловой системе только-для-чтения.
    
     - Удалены излишне строгие проверки в утилите `mdbx_chk`, которые
       приводили к ложно-позитивным ошибкам при проверке БД после серии
       последних доработок.
    
    Более подробная информация в [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    git diff' stat: 19 commits, 57 files changed, 751 insertions(+), 331 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.9
    v0.12.9 "Ясень-4"
    
    Стабилизирующий выпуск с исправлением обнаруженных ошибок и устранением недочетов.
    
    Исправления и доработки:
    ------------------------
    
     - Ликвидация зависимости от ранее удаленной опции `MDBX_ENABLE_PREFAULT`, из-за
       чего опция `MDBX_ENABLE_MINCORE` не включалась автоматически, что приводило
       к не-активации соответствующего улучшения и не-достижению  декларируемого уровня
       производительности в сценариях использования в режиме `MDBX_WRITEMAP`.
    
     - Исправление авто-установки `MDBX_ENV_CHECKPID` при отключении использования
       функционала `madvise()` посредством опции сборки `MDBX_ENABLE_MADVISE=0`.
       Из-за чего при поддержке системой `madvise(MADV_DONTFORK)` не включался контроль pid.
    
     - Добавлена проверка переданного ключа на `NULL` при обработке `MDBX_GET_MULTIPLE`.
    
     - Добавлена проверка номеров корневых страниц в `coherency_check()`.
    
     - Обеспечен `const` для начала и конца диапазона в аргументах `mdbx_estimate_range()`.
    
     - Из разрабатываемой версии перенесены не-нарушающие совместимости доработки C++ API:
    
         - добавлен тип `mdbx::cursor::estimation_result`, а поведение методов
          `cursor::estimate()` унифицировано с `cursor::move()`;
         - для предотвращения незаметного неверного использования API, для инициализации
           возвращаемых по ссылке срезов, вместо пустых срезов задействован `slice::invalid()`;
         - добавлены дополнительные C++ операторы преобразования к типам C API;
         - для совместимости со старыми стандартами C++ и старыми версиями STL перенесены
           в public классы `buffer::move_assign_alloc` и `buffer::copy_assign_alloc`;
         - добавлен тип `mdbx::default_buffer`;
         - для срезов и буферов добавлены методы `hex_decode()`, `base64_decode()`, `base58_decode()`;
         - добавлен тип `mdbx::comparator` и функций `mdbx::default_comparator()`;
         - добавлены статические методы `buffer::hex()`, `base64()`, `base58()`;
         - для транзакций и курсоров добавлены методы `get_/set_context`;
         - добавлен метод `cursor::clone()`;
    
     - Поддержка base58 приведена в соответствии с черновиком RFC.
    
     - Переработка/исправление `to_hex()` и `from_hex()`.
    
     - Уменьшение `MDBX_opt_rp_augment_limit` по умолчанию до 1/3 от текущего количества страниц в БД.
    
    Более подробная информация в [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    git diff' stat: 32 commits, 8 files changed, 667 insertions(+), 401 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.8
    v0.12.8 "Владимир Уткин"
    
    Стабилизирующий выпуск с исправлением обнаруженных ошибок и устранением недочетов,
    в день 100-летия со дня рождения выдающегося советского и российского ученого и конструктора [Влади́мира Фёдоровича У́ткина](https://ru.wikipedia.org/wiki/Уткин,_Владимир_Фёдорович).
    
    Исправления и доработки:
    ------------------------
    
     - Устранение регресса/ошибки в пути обработки `put(MDBX_MULTIPLE)` при пакетном/оптовом
       помещении в БД множественных значений одного ключа (aka multi-value или dupsort).
       Проявление проблемы зависит от компилятора и опций оптимизации/кодогенерации, но с большой вероятностью возвращется
       ошибка `MDBX_BAD_VALSIZE` (`-30781`), а в отладочных сборках срабатывает проверка `cASSERT(mc, !"Invalid key-size")`.
       Сценарии приводящие к другим проявлениям на данный момент не известны.
    
     - Реализована перезапись в `mdbx_put(MDBX_CURRENT)` всех текущих мульти-значений ключа
       при отсутствии флага `MDBX_NOOVERWRITE`. Ранее в такой ситуации возвращалась ошибка `MDBX_EMULTIVAL`.
       В текущем понимании новое поведение более удобно и не создаёт проблем совместимости с ранее написанным кодом.
    
     - Добавлена возможность использовать `mdbx_cursor_get(MDBX_GET_MULTIPLE)` без предварительной установки
       курсора, совмещая операцию пакетного получения данных с позиционированием курсора на передаваемый ключ.
    
     - Микрооптимизация и рефакторинг `cursor_put_nochecklen()` в продолжение исправления
       регресса/ошибки в пути обработки `put(MDBX_MULTIPLE)`.
    
     - Уточнение формулировок в описании API, в том числе пояснений о `SIGSEGV`
       и недопустимости прямого изменения данных.
    
    Более подробная информация в [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    git diff' stat: 24 commits, 18 files changed, 624 insertions(+), 94 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.7
    v0.12.7 "Артек"
    
    Стабилизирующий выпуск с исправлением обнаруженных ошибок и устранением недочетов,
    в день основания международного детского центра [«Арте́к»](https://ru.wikipedia.org/wiki/Артек).
    
    Исправления и доработки:
    ------------------------
    
      - Исправление опечатки в имени переменной внутри `mdbx_env_turn_for_recovery()`.
      - Обходное решение проблем сборки посредством GCC с использование опций `-m32 -arch=i686 -Ofast`.
      - Доработка режима "восстановления" БД и переключения на заданную мета-страницу.
    
      Более подробная информация в [ChangeLog](https://libmdbx.dqdkfa.ru/md__change_log.html).
    
    Мелочи:
    -------
    
     - Незначительное уточнение CMake-пробника для `std::filesystem`,
       проверяющего необходимость линковки с дополнительными библиотеками C++.
     - Устранение минорных предупреждений старых компиляторов в тестах.
     - Устранение причины ложно-позитивного предупреждения новых версий GCC в C++ API.
     - Исправление ссылки на репозиторий бенчмарка ioarena.
     - Добавление перекрестных ссылок в doxygen-документацию по C++ API.
     - Уточнение ограничений в разделе [Restrictions & Caveats](https://libmdbx.dqdkfa.ru/intro.html#restrictions).
     - Исправление ссылок на описание `mdbx_canary_put()`.
    
    14 files changed, 222 insertions(+), 56 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.6
    v0.12.6 "ЦСКА"
    
    Стабилизирующий выпуск с исправлением обнаруженных ошибок и устранением
    недочетов, в день 100-летнего юбилея спортивного клуба [«ЦСКА»](https://ru.wikipedia.org/wiki/Центральный_спортивный_клуб_Армии).
    
    Мелочи:
    -------
    
     - Обновление патча для старых версий buildroot.
     - Использование clang-format-16.
     - Использование `enum`-типов вместо `int` для устранения предупреждений GCC 13,
       что могло ломать сборку в Fedora 38.
    
    14 files changed, 117 insertions(+), 83 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.5
    v0.12.5 "Динамо"
    
    Стабилизирующий выпуск с исправлением обнаруженных ошибок и устранением
    недочетов, в день 100-летнего юбилея спортивного общества [«Динамо»](https://ru.wikipedia.org/wiki/Динамо_(спортивное_общество)).
    
    Благодарности:
    --------------
    
     - Max <maxc0d3r@protonmail.com> за сообщение о проблеме экспорта из DSO/DLL
       устаревших функций API.
    
     - [`@calvin3721`](https://t.me/calvin3721) за сообщение о проблеме работы
       `MainDB` с флагами не по-умолчанию.
    
    Исправления:
    ------------
    
     - Поправлен экспорт из DSO/DLL устаревших функций,
       которые заменены на inline в текущем API.
    
     - Устранено использование неверного компаратора при создании или пересоздании
       `MainDB` с флагами/опциями предполагающим использование специфического
       компаратора (не по-умолчанию).
    
    Мелочи:
    -------
    
     - Удалена дублирующая диагностика внутри `node_read_bigdata()`.
    
     - Исправлены ссылки в описании `mdbx_env_set_geometry()`.
    
     - Добавлен отдельный тест `extra/upsert_alldups` для специфического
       сценария замены/перезаписи одним значением всех multi-значений
       соответствующих ключу, т.е. замена всех «дубликатов» одним значением.
    
     - В C++ API добавлены варианты `buffer::key_from()` с явным именованием по типу данных.
    
     - Добавлен отдельный тест `extra/maindb_ordinal` для специфического
       сценария создания `MainDB` с флагами требующими использования
       компаратора не по-умолчанию.
    
     - Рефакторинг проверки "когерентности" мета-страниц.
    
     - Корректировка `osal_vasprintf()` для устранения предупреждений статических анализаторов.
    
    16 files changed, 686 insertions(+), 247 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.4
    0.12.4 "Арта-333"
    
    Стабилизирующий выпуск с исправлением обнаруженных ошибок, устранением
    недочетов и технических долгов. Ветка 0.12 считается готовой к
    продуктовому использованию, получает статус стабильной и далее будет
    получать только исправление ошибок. Разработка будет продолжена в ветке
    0.13, а ветка 0.11 становится архивной.
    
    Благодарности:
    --------------
    
     - Max <maxc0d3r@protonmail.com> за сообщение о проблеме ERROR_SHARING_VIOLATION
       в режиме MDBX_EXCLUSIVE на Windows.
     - Alisher Ashyrov <https://t.me/a1is43ras4> за сообщение о проблеме
       с assert-проверкой и содействие в отладке.
     - Masatoshi Fukunaga <https://gitflic.ru/user/mah0x211> за сообщение о проблеме
       `put(MDBX_UPSERT+MDBX_ALLDUPS)` для случая замены всех значений в subDb.
    
    Исправления (без корректировок новых функций):
    ----------------------------------------------
    
     - Устранен регресс после коммита 474391c83c5f81def6fdf3b0b6f5716a87b78fbf,
       приводящий к возврату ERROR_SHARING_VIOLATION в Windows при открытии БД
       в режиме MDBX_EXCLUSIVE для чтения-записи.
    
     - Добавлено ограничение размера отображения при коротком read-only файле, для
       предотвращения ошибки ERROR_NOT_ENOUGH_MEMORY в Windows, которая возникает
       в этом случае и совсем не информативна для пользователя.
    
     - Произведен рефакторинг `dxb_resize()`, в том числе, для устранения срабатывания
       assert-проверки `size_bytes == env->me_dxb_mmap.current` в специфических
       многопоточных сценариях использования. Проверка срабатывала только в
       отладочных сборках, при специфическом наложении во времени читающей и
       пишущей транзакции в разных потоках, одновременно с изменением размера БД.
       Кроме срабатывание проверки, каких-либо других последствий не возникало.
    
     - Устранена проблема в `put(MDBX_UPSERT+MDBX_ALLDUPS)` для случая замены
       всех значений единственного ключа в subDb. В ходе этой операции subDb
       становится полностью пустой, без каких-либо страниц и именно эта
       ситуация не была учтена в коде, что приводило к повреждению БД
       при фиксации такой транзакции.
    
     - Устранена излишняя assert-проверка внутри `override_meta()`.
       Что в отладочных сборках могло приводить к ложным срабатываниям
       при восстановлении БД, в том числе при автоматическом откате слабых
       мета-страниц.
    
     - Скорректированы макросы `__cold`/`__hot`, в том числе для устранения проблемы
       `error: inlining failed in call to ‘always_inline FOO(...)’: target specific option mismatch`
       при сборке посредством GCC >10.x для SH4.
    
    Ликвидация технических долгов и мелочи:
    ---------------------------------------
    
     - Исправлены многочисленные опечатки в документации.
     - Доработан тест для полной стохастической проверки `MDBX_EKEYMISMATCH` в режиме `MDBX_APPEND`.
     - Расширены сценарии запуска `mdbx_chk` из CMake-тестов для проверки как в обычном,
       так и эксклюзивном режимах чтения-записи.
     - Уточнены спецификаторы `const` и `noexcept` для нескольких методов в C++ API.
     - Устранено использование стека под буферы для `wchar`-преобразования путей.
     - Для Windows добавлена функция `mdbx_env_get_path()` для получения пути к БД
       в формате многобайтных символов.
     - Добавлены doxygen-описания для API с широкими символами.
     - Устранены предупреждения статического анализатора MSVC,
       все они были несущественные, либо ложные.
     - Устранено ложное предупреждение GCC при сборке для SH4.
     - Добавлена поддержка ASAN (Address Sanitizer) при сборке посредством MSVC.
     - Расширен набор перебираемых режимов в скрипте `test/long_stochastic.sh`,
       добавлена опция `--extra`.
     - В C++ API добавлена поддержка расширенных опций времени выполнения `mdbx::extra_runtime_option`,
       аналогично `enum MDBX_option_t` из C API.
     - Вывод всех счетчиков page-operations в `mdbx_stat`.
    
    63 files changed, 1161 insertions(+), 569 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.14
    0.11.14 "Sergey Kapitsa"
    
    The stable bugfix release in memory of [Sergey Kapitsa](https://en.wikipedia.org/wiki/Sergey_Kapitsa) on his 95th birthday.
    
    Fixes:
    ------
    
     - backport: Fixed insignificant typo of `||` inside `#if` byte-order condition.
    
     - backport: Fixed `SIGSEGV` or an erroneous call to `free()` in situations where
       errors occur when reopening by `mdbx_env_open()` of a previously used
       environment.
    
     - backport: Fixed `cursor_put_nochecklen()` internals for case when dupsort'ed named subDb
       contains a single key with multiple values (aka duplicates), which are replaced
       with a single value by put-operation with the `MDBX_UPSERT+MDBX_ALLDUPS` flags.
       In this case, the database becomes completely empty, without any pages.
       However exactly this condition was not considered and thus wasn't handled correctly.
       See [issue#8](https://gitflic.ru/project/erthink/libmdbx/issue/8) for more information.
    
     - backport: Fixed extra assertion inside `override_meta()`, which could
       lead to false-positive failing of the assertion in a debug builds during
       DB recovery and auto-rollback.
    
     - backport: Refined the `__cold`/`__hot` macros to avoid the
       `error: inlining failed in call to ‘always_inline FOO(...)’: target specific option mismatch`
       issue during build using GCC >10.x for SH4 arch.
    
    Minors:
    -------
    
     - backport: Using the https://libmdbx.dqdkfa.ru/dead-github
       for resources deleted by the Github' administration.
     - backport: Fixed English typos.
     - backport: Fixed proto of `__asan_default_options()`.
     - backport: Fixed doxygen-description of C++ API, especially of C++20 concepts.
     - backport: Refined `const` and `noexcept` for few C++ API methods.
     - backport: Fixed copy&paste typo of "Getting started".
     - backport: Update MithrilDB status.
     - backport: Resolve false-posirive `used uninitialized` warning from GCC >10.x
       while build for SH4 arch.
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    22 files changed, 250 insertions(+), 174 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.3
    v0.12.3 "Акула"
    
    Выпуск с существенными доработками и новой функциональностью в память о закрытом open-source проекте "Акула".
    
    Благодарности:
    --------------
    
     - [Alex Sharov](https://t.me/AskAlexSharov) и команде [Erigon](https://github.com/ledgerwatch/erigon) за тестирование.
     - [Simon Leier](https://t.me/leisim) за сообщение о сбоях и тестирование.
    
    Новое:
    ------
    
     - Использование адреса [https://libmdbx.dqdkfa.ru/dead-github](https://libmdbx.dqdkfa.ru/dead-github)
       для отсылки к сохранённым в web.archive.org копиям ресурсов, уничтоженных администрацией Github.
    
     - Реализована prefault-запись при выделении страниц для read-write отображений.
       Это приводит к кратному снижению системных издержек и существенному увеличению
       производительности в соответствующих сценариях использования, когда:
        - размер БД и объём данных существенно больше ОЗУ;
        - используется режим `MDBX_WRITEMAP`;
        - не-мелкие транзакции (по ходу транзакции выделяется многие сотни или тысячи страниц).
    
       В режиме `MDBX_WRITEMAP` выделение/переиспользование страниц приводит
       к page-fault и чтению страницы с диска, даже если содержимое страницы
       не нужно (будет перезаписано). Это является следствием работы подсистемы
       виртуальной памяти, а штатный способ лечения через `MADV_REMOVE`
       работает не на всех ФС и обычно дороже получаемой экономии.
    
       Теперь в libmdbx используется "упреждающая запись" таких страниц,
       которая на системах с [unified page cache](https://www.opennet.ru/base/dev/ubc.txt.html)
       приводит к "вталкиванию" данных, устраняя необходимость чтения с диска при
       обращении к такой странице памяти.
    
       Новый функционал работает в согласованности с автоматическим управлением read-ahead
       и кэшем статуса присутствия страниц в ОЗУ, посредством [mincore()](https://man7.org/linux/man-pages/man2/mincore.2.html).
    
     - Добавлена опция `MDBX_opt_prefault_write_enable` для возможности принудительного
       включения/выключения prefault-записи.
    
     - Реализован динамический выбор между сквозной записью на диск и обычной записью
       с последующим [fdatasync()](https://man7.org/linux/man-pages/man3/fdatasync.3p.html)
       управляемый опцией `MDBX_opt_writethrough_threshold`.
    
       В долговечных (durable) режимах данные на диск могут быть сброшены двумя способами:
         - сквозной записью через файловый дескриптор открытый с `O_DSYNC`;
         - обычной записью с последующим вызовом `fdatasync()`.
    
       Первый способ выгоднее при записи малого количества страниц и/или если
       канал взаимодействия с диском/носителем имеет близкую к нулю задержку.
       Второй способ выгоднее если требуется записать много страниц и/или канал
       взаимодействия имеет весомую задержку (датацентры, облака). Добавленная
       опция `MDBX_opt_writethrough_threshold` позволяет во время выполнения
       задать порог для динамического выбора способа записи в зависимости от
       объема и конкретных условия использования.
    
     - Автоматическая установка `MDBX_opt_rp_augment_limit` в зависимости от размера БД.
    
     - Запрещение разного режима `MDBX_WRITEMAP` между процессами в режимах
       с отложенной/ленивой записью, так как в этом случае невозможно
       обеспечить сброс данных на диск во всех случаях на всех поддерживаемых платформах.
    
     - Добавлена опция сборки `MDBX_MMAP_USE_MS_ASYNC` позволяющая отключить
       использование системного вызова `msync(MS_ASYNC)`, в использовании
       которого нет необходимости на подавляющем большинстве актуальных ОС.
       По-умолчанию `MDBX_MMAP_USE_MS_ASYNC=0` (выключено) на Linux и других
       системах с unified page cache. Такое поведение (без использования
       `msync(MS_ASYNC)`) соответствует неизменяемой (hardcoded) логике LMDB. В
       результате, в простых/наивных бенчмарках, libmdbx опережает LMDB
       примерна также как при реальном применении.
    
       На всякий случай стоит еще раз отметить/напомнить, что на Windows
       предположительно libmdbx будет отставать от LMDB в сценариях с
       множеством мелких транзакций, так как libmdbx осознанно использует на
       Windows файловые блокировки, которые медленные (плохо реализованы в ядре
       ОС), но позволяют застраховать пользователей от массы неверных действий
       приводящих к повреждению БД.
    
     - Поддержка не-печатных имен для subDb.
    
     - Добавлен явный выбор `tls_model("local-dynamic")` для обзода проблемы
       `relocation R_X86_64_TPOFF32 against FOO cannot be used with -shared`
       из-за ошибки в CLANG приводящей к использованию неверного режима `ls_model`.
    
     - Изменение тактики слияния страниц при удалении.
       Теперь слияние выполняется преимущественно с уже измененной/грязной страницей.
       Если же справа и слева обе страницы с одинаковым статусом,
       то с наименее заполненной, как прежде. В сценариях с массивным удалением
       это позволяет увеличить производительность до 50%.
    
     - Добавлен контроль отсутствия LCK-файлов с альтернативным именованием.
    
    Исправления (без корректировок новых функций):
    ----------------------------------------------
    
     - Изменение размера отображения если это требуется для сброса данных на
       диск при вызове `mdbx_env_sync()` из параллельного потока выполнения вне
       работающей транзакции.
    
     - Исправление регресса после коммита db72763de049d6e4546f838277fe83b9081ad1de от 2022-10-08
       в логике возврата грязных страниц в режиме `MDBX_WRITEMAP`, из-за чего
       освободившиеся страницы использовались не немедленно, а попадали в
       retired-список совершаемой транзакции и происходил необоснованный рост
       размера транзакции.
    
     - Устранение SIGSEGV или ошибочного вызова `free()` в ситуациях
       повторного открытия среды посредством `mdbx_env_open()`.
    
     - Устранение ошибки совершенной в коммите fe20de136c22ed3bc4c6d3f673e79c106e824f60 от 2022-09-18,
       в результате чего на Linux в режиме `MDBX_WRITEMAP` никогда не вызывался `msync()`.
       Проблема существует только в релизе 0.12.2.
    
     - Добавление подсчета грязных страниц в `MDBX_WRITEMAP` для предоставления посредством `mdbx_txn_info()`
       актуальной информации об объеме изменений в процессе транзакций чтения-записи.
    
     - Исправление несущественной опечатки в условиях `#if` определения порядка байт.
    
     - Исправление сборки для случая `MDBX_PNL_ASCENDING=1`.
    
    Ликвидация технических долгов и мелочи:
    ---------------------------------------
    
     - Доработка поддержки авто-слияния записей GC внутри `page_alloc_slowpath()`.
     - Устранение несущественных предупреждений Coverity.
     - Использование единого курсора для поиска в GC.
     - Переработка внутренних флагов связанных с выделением страниц из GC.
     - Доработка подготовки резерва перед обновлением GC при включенном BigFoot.
     - Оптимизация `pnl_merge()` для случаев неперекрывающихся объединяемых списков.
     - Оптимизация поддержки отсортированного списка страниц в `dpl_append()`.
     - Ускорение работы `mdbx_chk` при обработке пользовательских записей в `@MAIN`.
     - Переработка LRU-отметок для спиллинга.
     - Переработка контроля "некогерентности" Unified page cache для уменьшения накладных расходов.
     - Рефакторинг и микрооптимизация.
    
    20 files changed, 4504 insertions(+), 2924 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
  • v0.12.2
    v0.12.2 "Иван Ярыгин"
    
    Выпуск с существенными доработками и новой функциональностью
    в память о российском борце [Иване Сергеевиче Ярыгине](https://ru.wikipedia.org/wiki/Ярыгин,_Иван_Сергеевич).
    
    На Олимпийских играх в Мюнхене в 1972 году Иван Ярыгин уложил всех соперников на лопатки,
    суммарно затратив менее 9 минут. Этот рекорд никем не побит до сих пор.
    
    Новое:
    ------
    
     - Поддержка всех основных опций при сборке посредством CMake.
    
     - Требования к CMake понижены до версии 3.0.2 для возможности сборки для устаревших платформ.
    
     - Добавлена возможность профилирования работы GC в сложных и/или нагруженных
       сценариях (например Ethereum/Erigon). По-умолчанию соответствующий код отключен,
       а для его активации необходимо указать опцию сборки `MDBX_ENABLE_PROFGC=1`.
    
     - Добавлена функция `mdbx_env_warmup()` для "прогрева" БД с возможностью
       закрепления страниц в памяти.
       В утилиты `mdbx_chk`, `mdbx_copy` и `mdbx_dump` добавлены опции `-u` и `-U`
       для активации соответствующего функционала.
    
     - Отключение учета «грязных» страниц в не требующих этого режимах
       (`MDBX_WRITEMAP` при `MDBX_AVOID_MSYNC=0`). Доработка позволяет снизить
       накладные расходы и была запланирована давно, но откладывалась так как
       требовала других изменений.
    
     - Вытеснение из памяти (спиллинг) «грязных» страниц с учетом размера
       large/overflow-страниц. Доработка позволяет корректно соблюдать политику
       задаваемую опциями `MDBX_opt_txn_dp_limit`,
       `MDBX_opt_spill_max_denominator`, `MDBX_opt_spill_min_denominator` и
       была запланирована давно, но откладывалась так как требовала других
       изменений.
    
     - Для Windows в API добавлены UNICODE-зависимые определения макросов
      `MDBX_DATANAME`, `MDBX_LOCKNAME` и `MDBX_LOCK_SUFFIX`.
    
     - Переход на преимущественное использование типа `size_t` для
       уменьшения накладных расходов на платформе Эльбрус.
    
     - В API добавлены функции `mdbx_limits_valsize4page_max()` и
       `mdbx_env_get_valsize4page_max()` возвращающие максимальный размер в
       байтах значения, которое может быть размещена в одной
       large/overflow-странице, а не последовательности из двух или более таких
       страниц. Для таблиц с поддержкой дубликатов вынос значений на
       large/overflow-страницы не поддерживается, поэтому результат совпадает с
       `mdbx_limits_valsize_max()`.
    
     - В API добавлены функции `mdbx_limits_pairsize4page_max()`и
       `mdbx_env_get_pairsize4page_max()` возвращающие в байтах максимальный
       суммарный размер пары ключ-значение для их размещения на одной листовой
       страницы, без выноса значения на отдельную large/overflow-страницу. Для
       таблиц с поддержкой дубликатов вынос значений на large/overflow-страницы
       не поддерживается, поэтому результат определяет максимальный/допустимый
       суммарный размер пары ключ-значение.
    
     - Реализовано использование асинхронной (overlapped) записи в Windows,
       включая использования небуфферизированного ввода-вывода и `WriteGather()`.
       Это позволяет сократить накладные расходы и частично обойти проблемы
       Windows с низкой производительностью ввода-вывода, включая большие
       задержки `FlushFileBuffers()`. Новый код также обеспечивает консолидацию
       записываемых регионов на всех платформах, а на Windows использование
       событий (events) сведено к минимум, одновременно с автоматических
       использованием `WriteGather()`. Поэтому ожидается существенное снижение
       накладных расходов взаимодействия с ОС, а в Windows это ускорение, в
       некоторых сценариях, может быть кратным в сравнении с LMDB.
    
     - Добавлена опция сборки `MDBX_AVOID_MSYNC`, которая определяет
       поведение libmdbx в режиме `MDBX_WRITE_MAP` (когда данные изменяются
       непосредственно в отображенных в ОЗУ страницах БД):
    
        * Если `MDBX_AVOID_MSYNC=0` (по умолчанию на всех системах кроме Windows),
          то (как прежде) сохранение данных выполняется посредством `msync()`,
          либо `FlushViewOfFile()` на Windows. На платформах с полноценной
          подсистемой виртуальной памяти и адекватным файловым вводом-выводом
          это обеспечивает минимум накладных расходов (один системный вызов)
          и максимальную производительность. Однако, на Windows приводит
          к значительной деградации, в том числе из-за того что после
          `FlushViewOfFile()` требуется также вызов `FlushFileBuffers()`
          с массой проблем и суеты внутри ядра ОС.
    
        * Если `MDBX_AVOID_MSYNC=1` (по умолчанию только на Windows), то
          сохранение данных выполняется явной записью в файл каждой измененной
          страницы БД. Это требует дополнительных накладных расходов, как
          на отслеживание измененных страниц (ведение списков "грязных"
          страниц), так и на системные вызовы для их записи.
          Кроме этого, с точки зрения подсистемы виртуальной памяти ядра ОС,
          страницы БД измененные в ОЗУ и явно записанные в файл, могут либо
          оставаться "грязными" и быть повторно записаны ядром ОС позже,
          либо требовать дополнительных накладных расходов для отслеживания
          PTE (Page Table Entries), их модификации и дополнительного копирования
          данных. Тем не менее, по имеющейся информации, на Windows такой путь
          записи данных в целом обеспечивает более высокую производительность.
    
     - Улучшение эвристики включения авто-слияния записей GC.
    
     - Изменение формата LCK и семантики некоторых внутренних полей. Версии
       libmdbx использующие разный формат не смогут работать с одной БД
       одновременно, а только поочередно (LCK-файл переписывается при открытии
       первым открывающим БД процессом).
    
     - В `C++` API добавлены методы фиксации транзакции с получением информации
       о задержках.
    
     - Added `MDBX_HAVE_BUILT IN_CPU_SUPPORTS` build option to control use GCC's
       `__builtin_cpu_supports()` function, which could be unavailable on a fake
       OSes (macos, ios, android, etc).
    
    Исправления (без корректировок вышеперечисленных новых функций):
    ----------------------------------------------------------------
    
     - Устранения ряда предупреждений при сборке посредством MinGW.
     - Устранение ложно-положительных сообщений от Valgrind об использовании
       не инициализированных данных из-за выравнивающих зазоров в `struct troika`.
     - Исправлен возврат неожиданной ошибки `MDBX_BUSY` из функций `mdbx_env_set_option()`,
       `mdbx_env_set_syncbytes()` и `mdbx_env_set_syncperiod()`.
     - Небольшие исправления для совместимости с CMake 3.8
     - Больше контроля и осторожности (паранойи) для страховки от дефектов `mremap()`.
     - Костыль для починки сборки со старыми версиями `stdatomic.h` из GNU Lib C,
       где макросы `ATOMIC_*_LOCK_FREE` ошибочно переопределяются через функции.
     - Использование `fcntl64(F_GETLK64/F_SETLK64/F_SETLKW64)` при наличии.
       Это решает проблему срабатывания проверочного утверждения при сборке для
       платформ где тип `off_t` шире соответствующих полей `структуры flock`,
       используемой для блокировки файлов.
     - Доработан сбор информации о задержках при фиксации транзакций:
        * Устранено искажение замеров длительности обновления GC
          при включении отладочного внутреннего аудита;
        * Защита от undeflow-нуля только общей задержки в метриках,
          чтобы исключить ситуации, когда сумма отдельных стадий
          больше общей длительности.
     - Ряд исправлений для устранения срабатываний проверочных утверждения в
       отладочных сборках.
     - Более осторожное преобразование к типу `mdbx_tid_t` для устранения
       предупреждений.
     - Исправление лишнего сброса данных на диск в режиме `MDBX_SAFE_NOSYNC`
       при обновлении GC.
     - Fixed an extra check for `MDBX_APPENDDUP` inside `mdbx_cursor_put()`
       which could result in returning `MDBX_EKEYMISMATCH` for valid cases.
     - Fixed nasty `clz()` bug (by using `_BitScanReverse()`, only MSVC builds affected).
    
    Мелочи:
    -------
    
     - Исторические ссылки cвязанные с удалённым на ~~github~~ проектом  перенаправлены на [web.archive.org](https://web.archive.org/web/https://github.com/erthink/libmdbx).
     - Синхронизированны конструкции CMake между проектами.
     - Добавлено предупреждение о небезопасности RISC-V.
     - Добавлено описание параметров `MDBX_debug_func` и `MDBX_debug_func`.
     - Добавлено обходное решение для минимизации ложно-положительных
       конфликтов при использовании файловых блокировок в Windows.
     - Проверка атомарности C11-операций c 32/64-битными данными.
     - Уменьшение в 42 раза значения по-умолчанию для `me_options.dp_limit`
       в отладочных сборках.
     - Добавление платформы `gcc-riscv64-linux-gnu` в список для цели `cross-gcc`.
     - Небольшие правки скрипта `long_stochastic.sh` для работы в Windows.
     - Удаление ненужного вызова `LockFileEx()` внутри `mdbx_env_copy()`.
     - Добавлено описание использования файловых дескрипторов в различных режимах.
     - Добавлено использование `_CrtDbgReport()` в отладочных сборках.
     - Fixed an extra ensure/assertion check of `oldest_reader` inside `txn_end()`.
     - Removed description of deprecated usage of `MDBX_NODUPDATA`.
     - Fixed regression ASAN/Valgring-enabled builds.
     - Fixed minor MingGW warning.
    
    64 files changed, 5573 insertions(+), 2510 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
  • v0.11.13
    0.11.13 "Swashplate"
    
    The stable bugfix release in memory of [Boris Yuryev](https://ru.wikipedia.org/wiki/Юрьев,_Борис_Николаевич) on his 133rd birthday.
    
    Fixes:
    ------
    
     - Fixed builds with older libc versions after using `fcntl64()` (backport).
     - Fixed builds with  older `stdatomic.h` versions,
       where the `ATOMIC_*_LOCK_FREE` macros mistakenly redefined using functions (backport).
     - Added workaround for `mremap()` defect to avoid assertion failure (backport).
     - Workaround for `encryptfs` bug(s) in the `copy_file_range` implementation  (backport).
     - Fixed unexpected `MDBX_BUSY` from `mdbx_env_set_option()`, `mdbx_env_set_syncbytes()`
       and `mdbx_env_set_syncperiod()` (backport).
     - CMake requirements lowered to version 3.0.2 (backport).
     - Added admonition of insecure for RISC-V (backport).
    
    Minors:
    -------
    
     - Minor clarification output of `--help` for `mdbx_test` (backport).
     - Added admonition of insecure for RISC-V (backport).
     - Stochastic scripts and CMake files synchronized with the `devel` branch.
     - Use `--dont-check-ram-size` for small-tests make-targets (backport).
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    30 files changed, 405 insertions(+), 136 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.12
    0.11.12 "Эребуни"
    
    The stable bugfix release.
    
    Fixes:
    ------
    
     - Fixed static assertion failure on platforms where the `off_t` type is wider
       than corresponding fields of `struct flock` used for file locking (backport).
       Now _libmdbx_ will use `fcntl64(F_GETLK64/F_SETLK64/F_SETLKW64)` if available.
     - Fixed assertion check inside `page_retire_ex()` (backport).
    
    Minors:
    -------
    
     - Fixed `-Wint-to-pointer-cast` warnings while casting to `mdbx_tid_t` (backport).
     - Removed needless `LockFileEx()` inside `mdbx_env_copy()` (backport).
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    11 files changed, 96 insertions(+), 49 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.11
    0.11.11 "Тендра-1790"
    
    The stable bugfix release.
    It is planned that this will be the last release of the v0.11 branch.
    
    Fixes:
    ------
    
     - Fixed an extra check for `MDBX_APPENDDUP` inside `mdbx_cursor_put()` which could result in returning `MDBX_EKEYMISMATCH` for valid cases.
     - Fixed an extra ensure/assertion check of `oldest_reader` inside `mdbx_txn_end()`.
     - Fixed derived C++ builds by removing `MDBX_INTERNAL_FUNC` for `mdbx_w2mb()` and `mdbx_mb2w()`.
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    10 files changed, 38 insertions(+), 21 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>