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 chave de fragmento com hash ) em intervalos que não se sobrepõem. 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 chave de shard ideal permite que o MongoDB distribua documentos 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
Você pode alterar uma chave de shard de duas maneiras:
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
Documentos em sua coleção podem não ter campos especificados por sua chave de shard. Por padrão, os documentos que não têm campos especificados pela sua chave de shard estão na mesma faixa de chunk que as chaves de shard com valores nulos.
Para obter detalhes, consulte Definir campos de chave de fragmento ausentes.
Exibir uma chave de fragmento
Use para exibir a chave de shard usada para sua db.printShardingStatus() collection.
Para obter detalhes, consulte Exibir uma chave de fragmento.
Solução de problemas
Problemas comuns causados por uma chave de shard 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.