A chave do fragmento é um único campo indexado ou vários campos cobertos por um índice composto que determina a distribuição dos documentos da coleção entre os fragmentos do cluster. Para obter detalhes, consulte Índices de chave de fragmento.
O MongoDB divide a extensão de valores de chaves de fragmentação (ou valores de chaves de fragmentação com hash) em intervalos que não se sobrepõem de valores de chaves de fragmentação (ou valores de chaves de fragmentação com hash). Cada intervalo está associado a um bloco, e o MongoDB tenta distribuir os blocos uniformemente entre os fragmentos no cluster.
Fragmentar uma Coleção
Você pode usar o método mongosh sh.shardCollection() para fragmentar uma coleção. Para fragmentar uma collection, você deve especificar o namespace completo da collection que você deseja fragmentar e a chave de fragmento.
sh.shardCollection(<namespace>, <key>) // Optional parameters omitted
| Especifique o namespace completo da collection que você quer fazer o shard ( |
| Especifique um documento
|
Para ver mais informações sobre o método de fragmentação, consulte sh.shardCollection().
Escolher uma chave de fragmentação
A escolha da chave de fragmento afeta a criação e a distribuição de dados entre os fragmentos disponíveis. A distribuição de dados afeta a eficiência e o desempenho das operações dentro do cluster fragmentado. A chave de fragmento ideal permite que o MongoDB distribua documents uniformemente em todo o cluster, ao mesmo tempo em que facilita padrões de query comuns.
Para obter detalhes, consulte a página Escolher uma chave de fragmento.
Alterar uma chave de fragmentação
O MongoDB oferece duas maneiras de alterar uma chave de fragmento. Como alterar uma chave de fragmento:
Você pode refinar uma chave de fragmento adicionando campos à chave existente.
Você pode alterar uma chave de fragmento completamente e refragmentar uma coleção com a nova chave.
Para obter detalhes, consulte a página Alterar uma chave de fragmento.
Alterar valor do campo chave de fragmento de um document
Você pode alterar o valor do campo chave do fragmento em qualquer document da sua collection, a menos que o campo chave do fragmento seja o campo _id. Isso pode afetar em qual fragmento o document vive.
Para obter detalhes, consulte Alterar o valor da chave de shard de um documento.
Definir campos de chave de fragmentação ausentes
É possível que os documentos em sua coleção não tenham campos especificados por sua chave de fragmento. Por padrão, os **documents** que não têm **campos** especificados pela sua **chave de fragmento** vivem na mesma **faixa** de **parte** que as **chaves de fragmento** com valores nulos.
Para obter detalhes, consulte Definir campos de chave de fragmento ausentes.
Exibir uma chave de fragmento
Você pode usar o método db.printShardingStatus() para exibir a chave de fragmento usada para sua coleção.
Para obter detalhes, consulte Exibir uma chave de fragmento.
Solução de problemas
Alguns problemas comuns de chave de fragmento causados por uma chave de fragmento abaixo do ideal são:
Partes jumbo
Distribuição de carga irregular
Diminuição do desempenho da query
Para obter detalhes, consulte Solucionar problemas de chave de fragmento.