Limbo: асинхронная SQLite для бессерверных вычислений

Исследователи создали Limbo – переписанную на Rust версию SQLite, использующую io_uring для асинхронного ввода/вывода. Это позволяет избежать блокировки потока приложения во время дисковых операций. Архитектура Limbo перестроена на уровнях виртуальной машины и B-дерева, заменяя синхронные инструкции байт-кода на асинхронные аналоги.
Limbo: асинхронная SQLite для бессерверных вычислений
Изображение носит иллюстративный характер

При тестировании в мультиарендной бессерверной среде Limbo продемонстрировала 100-кратное снижение задержки при p999 по сравнению с оригинальной SQLite. Этот результат достигается за счет параллельного выполнения вычислительных задач и задач ввода/вывода, уменьшая конкуренцию за ресурсы.

Несмотря на значительное ускорение, есть вопросы о совместимости Limbo с SQL и SQLite. Важно отметить, что гарантия порядка записи при асинхронном I/O требует особого внимания для обеспечения целостности данных. Необходимо дальнейшее изучение баланса между асинхронностью и транзакционностью.

Следует учитывать, что большая часть выигрыша в скорости Limbo достигается при высоких перцентилях задержки (p999), тогда как при p90 и p99 производительность практически равна SQLite. Также не ясно, насколько результаты эксперимента зависят от неполной реализации транзакций в Limbo.


Новое на сайте

19806Зелёная и коричневая луна: почему геологи Artemis II уже не могут усидеть на месте 19805Эксперты уверены в теплозащитном щите Artemis II, несмотря на проблемы предшественника 19804Выжить внутри торнадо: каково это — когда тебя засасывает в воронку 19803Аляскинские косатки-охотники на млекопитающих замечены у берегов Сиэтла 19802Танец льва на краю Канады: как диаспора переизобретает традицию 19801Одна буква в днк превратила самок мышей в самцов 19800Аошима: крошечный японский остров, захваченный кошками 19799Уязвимость в Marimo начали эксплуатировать меньше чем через 10 часов после публикации 19798Почему возвращение экипажа Artemis II на землю считают самым опасным этапом лунной миссии? 19797Расширения с ИИ в браузере: угроза, которую корпоративная безопасность проглядела 19796ИИ в военных симуляциях почти всегда выбирает ядерный удар 19795Как Google в Chrome 146 привязала сессии к железу и обесценила украденные куки? 19794Бэкдор в обновлении Smart Slider 3 Pro: шесть часов, которые поставили под удар сотни... 19793Зачем древние корейцы приносили людей в жертву и вступали в близкородственные браки? 19792Уязвимость в EngageLab SDK поставила под удар 50 миллионов Android-устройств
Ссылка