Compartilhar via


Função ClfsAddLogContainerSet (wdm.h)

A rotina ClfsAddLogContainerSet adiciona atomicamente um conjunto de contêineres a um log CLFS.

Sintaxe

CLFSUSER_API NTSTATUS ClfsAddLogContainerSet(
  [in]           PLOG_FILE_OBJECT plfoLog,
  [in]           USHORT           cContainers,
  [in, optional] PULONGLONG       pcbContainer,
  [in]           PUNICODE_STRING  rguszContainerPath
);

Parâmetros

[in] plfoLog

Um ponteiro para uma estrutura LOG_FILE_OBJECT que representa o log ao qual os contêineres serão adicionados. O chamador obteve esse ponteiro anteriormente chamando ClfsCreateLogFile.

[in] cContainers

O número de contêineres no conjunto. Esse é o número de elementos na matriz rguszContainerPath .

[in, optional] pcbContainer

Um ponteiro para uma variável do tipo ULONGLONG. A função desse parâmetro depende se o log atualmente tem pelo menos um contêiner.

  • Se o log atualmente não tiver contêineres, o chamador fornecerá um inteiro positivo que é o tamanho solicitado, em bytes, de um contêiner individual. O CLFS cria contêineres que são o tamanho solicitado arredondado para um múltiplo de 512 KB (para um log dedicado) ou 1 MB (para um log multiplexado).
  • Se o log atualmente tiver pelo menos um contêiner e esse parâmetro for o ponteiro NULL , o CLFS criará novos contêineres do mesmo tamanho que os contêineres existentes. (Todos os contêineres em um log devem ter o mesmo tamanho.)
  • Se o log atualmente tiver pelo menos um contêiner e esse parâmetro for um ponteiro válido, o chamador fornecerá um inteiro positivo que é o tamanho solicitado, em bytes, de um contêiner individual. O tamanho solicitado é arredondado para um múltiplo de 512 KB (para um log dedicado) ou 1 MB (para um log compartilhado). Se o tamanho arredondado for pelo menos tão grande quanto o tamanho do contêiner existente, o CLFS criará novos contêineres do mesmo tamanho que os contêineres existentes. No retorno bem-sucedido, esse parâmetro recebe o tamanho do contêiner existente. Se o tamanho arredondado for menor que o tamanho do contêiner existente, ClfsAddLogContainerSet falhará.

[in] rguszContainerPath

Um ponteiro para uma matriz de estruturas UNICODE_STRING . Cada cadeia de caracteres fornece o nome do caminho para um dos novos contêineres. O número de elementos na matriz é fornecido por cContainers. Um determinado caminho pode ser absoluto ou relativo ao local do arquivo de log base. Os caminhos relativos ao arquivo de log base devem começar com CLFS_CONTAINER_RELATIVE_PREFIX, que é o literal de cadeia de caracteres (L"%BLF%\").

Retornar valor

ClfsAddLogContainer retornará STATUS_SUCCESS se tiver êxito; caso contrário, ele retornará um dos códigos de erro definidos em Ntstatus.h.

Comentários

Um contêiner é uma extensão contígua no armazenamento estável. Por exemplo, um contêiner pode ser um arquivo contíguo no disco. Um log é um conjunto de contêineres junto com um arquivo de log base. Para obter mais informações sobre contêineres, consulte Armazenamento estável CLFS.

Um contêiner especificado por um caminho relativo ao arquivo de log base deve estar no mesmo diretório que o arquivo de log base ou um subdiretório do arquivo de log base. Os diretórios "." e "." não são permitidos em um caminho relativo.

Um log pode ter alguns contêineres com caminhos absolutos e outros contêineres com caminhos relativos.

Os contêineres são criados em um modo não compactado e são inicializados com zeros.

Um log deve ter pelo menos dois contêineres antes que qualquer E/S possa ser executada nele.

Para obter uma explicação dos conceitos e terminologia do CLFS, consulte Common Log File System.

Requisitos

Requisito Valor
Cliente mínimo com suporte Disponível no Windows Server 2003 R2, Windows Vista e versões posteriores do Windows.
Plataforma de Destino Área de Trabalho
Cabeçalho wdm.h (include Wdm.h)
Biblioteca Clfs.lib
DLL Clfs.sys
IRQL <= APC_LEVEL

Confira também

ClfsAddLogContainer

ClfsRemoveLogContainerSet