169 похожих чатов

До сих пор все было отлично, но как нам прежде

всего отсортировать данные по
ключу? Входящие операции записи могут производиться в любом порядке.
Поддержание отсортированной структуры на диске возможно (см. подраздел
«B-деревья» текущего раздела), но гораздо проще будет делать это в оперативной памяти. Существует множество доступных для использования хорошо
известных древовидных структур данных, например красно-черные деревья или
AVL-деревья [2]. При использовании этих структур можно вставлять ключи в любой
последовательности и затем читать их в нужном порядке.
Теперь мы организуем работу нашей подсистемы хранения следующим образом.
‰ При поступлении записи добавляем ее в располагающуюся в оперативной памяти сбалансированную структуру данных (например, красно-черное дерево).
Это располагающееся в оперативной памяти дерево называется MemTable
(от memory table — «таблица, расположенная в памяти»).
‰ Когда размер MemTable превышает определенное пороговое значение — обычно несколько мегабайт, — записываем его на диск в виде файла SS-таблицы.
Эта операция выполняется достаточно эффективно, поскольку дерево поддерживает пары «ключ — значение» в отсортированном по ключу виде. Новый файл
SS-таблицы становится последним сегментом базы данных. А пока SS-таблица
записывается на диск, операции записи продолжают выполняться в новый
экземпляр MemTable.
‰ Для обслуживания запроса на чтение сначала пробуем найти ключ в MemTable,
затем в последнем по времени сегменте на диске, затем в предпоследнем и т. д.
‰ Время от времени запускаем в фоне процесс слияния и уплотнения, чтобы объединить файлы сегментов и отбросить перезаписанные или удаленные значения.
Представленная схема работает отлично. У нее есть только одна проблема: если
происходит фатальный сбой БД, то записанные позже всего данные (находящиеся
в MemTable, но еще не записанные на диск) теряются. Чтобы избежать этой проблемы, можно держать на диске отдельный журнал, в конец которого немедленно
добавляются все записываемые данные, точно так же, как в предыдущем разделе.
Сам журнал неупорядочен, но это неважно, ведь его единственное назначение —
восстановление MemTable после сбоя. Всякий раз, когда MemTable записывается
в SS-таблицу, соответствующий журнал можно удалять.

2 ответов

14 просмотров

Это что?

Dima- Автор вопроса
Misha
Это что?

Создание и поддержание SS-таблиц

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
14
Ребят, чет я уже не догоняю... Крч в коде на асм там происходит нечто вроде a+число (a+1, a+2 и т.д.). Но почему строка lea ecx, [edx+1] работает как a+1?? В edx берется адрес...
Alan 🔝 Бэброу
4
Карта сайта