Capped collections
Visão geral
As coleções limitadas são coleções de tamanho fixo que oferecem suporte a operações de alta taxa de transferência que inserem e recuperam documentos com base na ordem de inserção. As coleções limitadas funcionam de maneira semelhante aos buffers circulares: uma vez que uma coleção preenche seu espaço alocado, ela abre espaço para novos documentos substituindo os documentos mais antigos da coleção.
Consulte createCollection()
ou create
para obter mais informações sobre a criação de capped collections.
Dica
Como alternativa às capped collections, considere os índices TTL (Time To Live) do MongoDB. Conforme descrito em Expirar dados de collections definindo compilações de índices TTL, esses índices permitem que você expire e remova dados de collections normais com base no valor de um campo do tipo data e em um valor TTL para o índice.
Os índices TTL não são compatíveis com coletas limitadas. Você pode criar um índice na collection, mas o mongod
não exclui documentos expirados.
Comportamento
Ordem de inserção
Coletas limitadas garantem a preservação do pedido de inserção. Como resultado, as consultas não precisam de um índice para retornar documentos na ordem de inserção. Sem essa sobrecarga de indexação, as coletas limitadas podem suportar uma maior taxa de transferência de inserção.
Remoção automática dos documentos mais antigos
As capped collections removem automaticamente os documentos mais antigos para dar lugar a novos, sem a necessidade de roteiros ou comandos de exclusão manuais.
Considere os seguintes casos de uso possíveis para capped collections:
Armazenar informações de log geradas por sistemas de alto volume. A inserção de documentos em uma coleção limitada sem índice demora mais ou menos como uma escritura de informações de log diretamente em um sistema de arquivos. Além disso, a propriedade incorporada de primeiro a entrar, primeiro a sair mantém a ordem dos eventos e gerencia o uso do armazenamento.
Armazene em cache pequenas quantidades de dados em capped collections. Como os caches são mais pesados para leitura do que para escritura, você precisaria garantir que essa collection permaneça sempre no conjunto de trabalho (ou seja, na RAM) ou aceitar alguma penalidade de escritura para o índice ou os índices necessários.
Por exemplo, o oplogReplica Set , que armazena um registro das operações em um conjunto de réplicas , usa uma collection limitada. Diferentemente de outras coletas limitadas, o oplog pode ultrapassar o limite de tamanho configurado para evitar a exclusão do majority
commit point
.
_id
Index
As coletas mapeadas têm um campo _id
e um índice no campo _id
por padrão.
Restrições e recomendações
Lê
A partir do MongoDB 5.0, você não pode utilizar a preocupação de leitura "snapshot"
ao ler de uma coleção limitada.
Updates
Se você planeja atualizar documentos em uma capped collection, crie um índice para que essas operações de atualização não exijam uma varredura da collection.
Tamanho do documento
Se uma atualização ou uma operação de substituição alterar o tamanho do documento , a operação falhará.
Fragmentação
Você não pode fragmentar uma coleta limitada.
Eficiência da query
Use a ordem natural para recuperar os elementos inseridos mais recentemente da coleta de forma eficiente. Isto é semelhante ao uso do comando tail
em um arquivo de log.
Agregação $out
O estágio de pipeline de agregação $out
não pode gravar resultados em uma coleção limitada.
Transações
Não é possível escrever em capped collections em transações.
Stable API
Capped collections não são aceitas na Stable API V1.
Procedimentos
Criar uma collection com limite
Você deve criar capped collections explicitamente utilizando o método db.createCollection()
, que é um assistente do mongosh
para o comando create
. Ao criar uma collection limitada, você deve especificar o tamanho máximo da collection em bytes, que o MongoDB pré-aloca para ela. O tamanho da collection limitada inclui um pequeno volume de espaço para a sobrecarga interna.
db.createCollection( "log", { capped: true, size: 100000 } )
Se o campo size
for menor ou igual a 4096, a coleção terá um limite de 4096 bytes. Caso contrário, o MongoDB aumentará o tamanho fornecido para torná-lo um número inteiro múltiplo de 256.
Além disso, você também pode especificar um número máximo de documentos para a collection usando o campo max
como no seguinte documento:
db.createCollection("log", { capped : true, size : 5242880, max : 5000 } )
Importante
O argumento size
é sempre exigido, mesmo quando você especifica o número max
de documentos. O MongoDB remove documento mais antigos se uma collection atingir o limite de tamanho máximo antes de ela atingir a contagem máxima de documento.
Consultar uma Coleção Limitada
Se você executar um find()
em uma capped collection sem nenhuma ordem especificada, o MongoDB garantirá que a ordem dos resultados seja igual à ordem de inserção.
Para recuperar documentos na ordem inversa de inserção, execute find()
junto com o método sort()
com o parâmetro $natural
definido como -1
, conforme o exemplo a seguir:
db.cappedCollection.find().sort( { $natural: -1 } )
Verifique se uma coleta está limitada
Utilize o método isCapped()
para determinar se uma collection é capped, da seguinte forma:
db.collection.isCapped()
Converter uma coleta em limitada
Você pode converter uma coleção sem limite em uma coleção limitada com o comandoconvertToCapped
:
db.runCommand({"convertToCapped": "mycoll", size: 100000});
O parâmetro size
especifica o tamanho da capped collection em bytes.
Isso mantém uma trava exclusiva do banco de dados durante a operação. Outras operações que travam o mesmo banco de dados serão bloqueadas até a operação ser concluída. Consulte Quais travas são feitas por algumas operações comuns do cliente? para saber quais operações travam o banco de dados.
Cursor atualizado
Você pode usar um cursor tailable com coleções limitadas. Semelhante ao comando Unix tail -f
, o cursor tailable "tails" o final de uma coleção limitada. À medida que novos documentos são inseridos na coleção limitada, você pode usar o cursor tailable para continuar recuperando documentos.
Veja Cursores Tailable para obter informações sobre como criar um cursor tailable.