Общая файловая система журнала - Common Log File System

Общая файловая система журнала (CLFS) - это универсальная подсистема ведения журнала, доступная как для режим ядра а также пользовательский режим приложения для построения высокопроизводительных сделка журналы. Он был введен с Windows Server 2003 R2 и включен в более поздние версии Windows операционные системы. CLFS можно использовать как для Регистрация данных а также для регистрация событий. CLFS используется TxF и TxR для сохранения изменений состояния транзакции до того, как они зафиксируют транзакцию. Двоичные файлы журнала, созданные из CLFS, не могут быть просмотрены ни одним встроенным инструментом Windows.

Обзор

Задача CLFS, как и любой другой системы регистрации транзакций, состоит в том, чтобы записывать серию шагов, необходимых для некоторых действий, чтобы их можно было либо точно воспроизвести в будущем, чтобы зафиксировать транзакцию во вторичном хранилище, либо отменить, если потребуется. CLFS сначала маршалы записывает записи в буферы в памяти, а затем записывает их в файлы журнала на вторичное хранилище (стабильные СМИ в терминологии CLFS) для постоянного сохранения. Когда данные будут сброшены на стабильный носитель, это контролируется встроенными политиками, но клиентское приложение CLFS может отменить это и принудительно выполнить сброс. CLFS позволяет настраивать форматы журналов, расширять и усекать журналы в соответствии с определенными политиками, а также одновременно использовать несколько клиентских приложений. CLFS может хранить файлы журнала в любом месте файловой системы.[1]

CLFS определяет драйвер устройства интерфейс (DDI), через который драйверы для физических систем хранения подключаются к CLFS API. Драйвер CLFS реализует ОВЕН алгоритм восстановления; другие алгоритмы могут поддерживаться с помощью специальных драйверов.[1]

CLFS поддерживает как выделенные, так и мультиплексированные журналы. Выделенный журнал содержит один поток записей журнала, тогда как мультиплексированный журнал содержит несколько потоков, каждый поток для отдельного приложения. Несмотря на то, что мультиплексированный журнал имеет несколько потоков, журналы сбрасываются в потоки последовательно, одним пакетом. CLFS может заранее выделить место для набора записей журнала (до фактического создания журналов), чтобы убедиться, что операция не завершится неудачно из-за нехватки места для хранения.[1]

Запись журнала в потоке CLFS сначала помещается в Блок ввода-вывода журнала в буфере в системной памяти. Периодически блоки сбрасываются на стабильные устройства хранения. На устройстве хранения журнал содержит набор Контейнеры, которые размещаются непрерывно, каждый из которых содержит несколько блоков ввода-вывода журнала. Новые записи журнала добавляются к текущему набору. Каждая запись обозначается значком Порядковый номер журнала (LSN), возрастающий 32-битный порядковый номер. LSN и другие метаданные хранятся в заголовке записи. LSN кодирует идентификатор контейнера, смещение записи и идентификатор записи - эта информация используется для последующего доступа к записи журнала. Однако идентификаторы контейнеров являются логическими идентификаторами, они должны быть сопоставлены с физическими контейнерами. Отображение выполняется самой CLFS.[2]

использованная литература

  1. ^ а б c «Введение в общую файловую систему журнала». MSDN. Получено 2018-01-08.
  2. ^ «Стабильное хранилище CLFS». MSDN. Получено 2018-01-08.

внешняя ссылка