Um cluster fragmentado MongoDB consiste nos seguintes componentes:
fragmento: cada fragmento contém um subconjunto dos dados fragmentados. Cada fragmento deve ser implantado como um conjunto de réplicas.
Roteamento com
mongos
: Omongos
atua como um roteador de query, fornecendo uma interface entre os aplicativos clientes e o cluster fragmentado.servidores de configuração: os servidores de configuração armazenam metadados e definições de configuração para o cluster. Os servidores de configuração devem ser implantados como um conjunto de réplicas (CSRS).
Configuração de produção
Em um cluster de produção, certifique-se de que os dados sejam redundantes e que seus sistemas estejam altamente disponíveis. Considere o seguinte ao implantar um cluster fragmentado de produção:
Distribuir servidores de configuração como um conjunto de réplicasde 3 nós
Implante cada shard como um conjunto de réplicas de três membros
Distribua um ou mais roteadores
mongos
Distribuição do conjunto de réplicas
Para sistemas de produção, recomendamos distribuir conjuntos de réplicas de servidor de configuração e fragmento em pelo menos três data centers. Essa configuração fornece alta disponibilidade caso um único centro de dados fique inativo.
Número de shards
A fragmentação exige pelo menos dois shards para distribuir os dados fragmentados. Clusters fragmentados de shard único podem ser úteis se você planeja habilitar uma fragmentação em um futuro próximo, mas não precisa fazê-lo no momento da implementação.
Número de mongos
e distribuição
Os roteadores mongos
suportam alta disponibilidade e escalabilidade ao implantar várias instâncias mongos
. Se um proxy ou balancer de carga estiver entre o aplicativo e os roteadores mongos
, você deve configurá-lo para afinidade do cliente. A afinidade do cliente permite que cada conexão de um único cliente alcance o mesmo mongos
. Para alta disponibilidade de shard:
Adicione instâncias
mongos
no mesmo hardware em que instânciasmongos
já estão em execução.Incorpore roteadores
mongos
no nível do aplicativo.
mongos
roteadores se comunicam frequentemente com seus servidores de configuração . À medida que você aumenta o número de roteadores, o desempenho pode se degradar. Se o desempenho se degradar, reduza o número de roteadores.
O diagrama a seguir mostra uma arquitetura de cluster fragmentada comum usada na produção:

Configuração de desenvolvimento
Para teste e desenvolvimento, você pode implantar um cluster fragmentado com um número mínimo de componentes. Esses clusters que não são de produção têm os seguintes componentes:
Uma instância
mongos
.Um único conjunto de réplicas de shard.
Um servidor de configuração do conjunto de réplicas.
O diagrama a seguir mostra uma arquitetura de cluster fragmentado usada somente para desenvolvimento:

Aviso
Use a arquitetura de cluster de teste apenas para teste e desenvolvimento.