O diagrama a seguir mostra o Aplicativo de Ops Manager, o Banco de Dados do Aplicativo, o Backup Daemon e os Volumes persistentes correspondentes implantados em vários clusters do Kubernetes.
Neste diagrama:
O
Member Cluster 0também é um "cluster de operadores" porque você instala o Operador Kubernetes nele. Ele também é um "cluster de membros" e pode hospedar qualquer recurso personalizado de vários clusters.O
Member Cluster 0armazena os arquivos kubeconfig, que descrevem a configuração do Kubernetes para clusters de membros, usuários e contextos. Quando você configura o Operador Kubernetes para sistemas de vários clusters usando o plugin-inkubectl mongodb, ele cria o seguinte recurso:O segredo
mongodb-enterprise-operator-multi-cluster-kubeconfig, que contém as credenciais de todos os clusters Kubernetes que o Operador Kubernetes vai gerenciar. Se você planeja usar o cluster do operador como um cluster de membros, esse segredo poderá conter as credenciais do mesmo cluster onde você instalará o Kubernetes Operator.
Quando o Operador Kubernetes é executado nomodo de vários clusters , ele armazena os recursos necessários, como ConfigMaps e segredos sobre os clusters que ele vai gerenciar. Estes recursos pertencem ao mesmo namespace que o Operador Kubernetes. O Operador do Kubernetes usa esses recursos para implantar o Aplicativo de MongoDB Ops Manager e o Banco de Dados de Aplicativos em vários clusters do Kubernetes .
O Operador Kubernetes também cria e mantém alguns ConfigMaps adicionais de estado de implantação de vários clusters para cada aplicativo MongoDB Ops Manager e sistema de banco de dados de aplicativos que gerencia. O
Member Cluster 0armazena esta configuração, que inclui os seguintes ConfigMaps:O
<om_resource_name>-cluster-mappingConfigMap contém o mapeamento de nomes de cluster de membros listados emspec.clusterSpecListpara índices de cluster, referenciados nesta documentação comocluster_index, comoCluster 0ouCluster 1. O Operador Kubernetes atribui estes índices a cada nome de cluster.O
<om_resource_name>-db-cluster-mappingConfigMap contém o mapeamento dos nomes do cluster de membros listados emspec.applicationDatabase.clusterSpecListpara índices de cluster.O
<om_resource_name>-db-member-specConfigMap contém o número de réplicas do Banco de Dados de Aplicativo configurados para cada agrupamento de membro. Ter essas informações permite que o operador do Kubernetes dimensione ou reconfigure corretamente o conjunto de réplicas como parte da recuperação de desastres, como após a perda de todo o cluster de membros.
A configuração do recurso
MongoDBOpsManageré um arquivo que você cria e que descreve um sistema do MongoDB Ops Manager de vários clusters. O Operador Kubernetes usa este arquivo para implantar os componentes do MongoDB Ops Manager .O exemplo a seguir mostra a configuração que leva o Operador Kubernetes a implantar os componentes do MongoDB Ops Manager descritos neste diagrama. Este exemplo omite algumas configurações que não são relevantes para este diagrama, como a configuração doTLS do .
1 apiVersion: mongodb.com/v1 2 kind: MongoDBOpsManager 3 metadata: 4 name: om 5 namespace: om-ns 6 spec: 7 replicas: 1 # You can set this value and use it as a global or default 8 # setting for all clusters. The spec.clusterSpecList.members 9 # setting overrides this setting. 10 topology: MultiCluster 11 version: 8.0.0 12 adminCredentials: om-admin-secret 13 clusterSpecList: 14 - clusterName: "Member Cluster 1" # Ops Manager settings for "Member Cluster 1" 15 members: 2 16 backup: # Backup settings for "Member Cluster 1" 17 members: 2 # Overrides spec.backup.members 18 - clusterName: "Member Cluster 2" # Ops Manager settings for "Member Cluster 2" 19 members: 1 20 backup: # Backup settings for "Member Cluster 2" 21 members: 2 # Overrides spec.backup.members 22 applicationDatabase: # Global {+appdb+} settings 23 topology: MultiCluster 24 version: 8.0.0 25 members: 3 # In multi-cluster mode, the Operator ignores this field. 26 # The Operator sets the number of members for the Application 27 # Database in spec.applicationDatabase.clusterSpecList.members. 28 clusterSpecList: 29 - clusterName: "Member Cluster 1" 30 members: 3 31 - clusterName: "Member Cluster 2" 32 members: 2 33 backup: # Global settings for the Backup Daemon 34 enabled: true 35 members: 1 # Set this value and use it as a global or default setting. 36 # To override this value, set the value for 37 # spec.clusterSpecList.backup.members. 38 # The Backup Daemon's configuration for each cluster isn't 39 # stored here. Use the Ops Manager's spec.clusterSpecList.backup to 40 # specify the Backup Daemon configuration for each member cluster. O operador Kubernetes se conecta às instâncias do MongoDB Ops Manager fazendo referência a:
O FQDN padrão do serviço que ele cria para o recurso do MongoDB Ops Manager ,
<om_resource_name>-svc.<namespace>.svc.cluster.localouA URL que você especifica no
spec.opsManagerURL. Em algumas implantações, como quando o cluster onde você instalou o Operador Kubernetes não está anexado à tela de serviço, o FQDN de serviço padrão pode estar inacessível. Nesse caso, o Operador do Kubernetes relata o status do recursoMongoDBOpsManagercomoFailed, indicando um erro de conexão. Para levar em conta esses casos, forneça a URL ao MongoDB Ops Manager nospec.opsManagerURL. Essa URL pode ser o nome do host de uma instância MongoDB Ops Manager exposta externamente. Para saber mais, consulte Visão geral de rede.
Dois clusters de membros hospedam o aplicativoMongoDB Ops Manager . Em cada cluster, o Operador Kubernetes implementa um StatefulSet denominado
<om_resource_name>-<cluster_index>.O StatefulSet implementa duas instâncias do Aplicativo MongoDB Ops Manager no
Member Cluster 1e uma instância noMember Cluster 2.Você define o número de instâncias no
spec.clusterSpecList.members. Você pode definir o número de instâncias como zero para que esse cluster não implante nenhuma instância do Aplicativo de MongoDB Ops Manager . Isso é útil se, por exemplo, você quiser usar esse cluster para hospedar apenas instâncias do Backup Daemon .Se você remover um cluster de
spec.clusterSpecList, isso será equivalente a especificar zero nós emspec.clusterSpecList.membersespec.clusterSpecList[*].backup.members.Para cada StatefulSet em cada cluster, o Operador Kubernetes configura um serviço do tipo
ClusterIP, denominado<om_resource_name>-svc, que contém todos os Pods na lista de endpoints do cluster. O FQDN,<om_resource_name>-svc.<namespace>.svc.cluster.localdeste serviço é um nome de host padrão que o Operador do Kubernetes usa para acessar o endpoint implementado para o Aplicativo Ops Manager.Se você especificar
spec.externalConnectivity, o Operador Kubernetes também criará um serviço externo do tipo KubernetesLoadBalancer, chamado<om_resource_name>-svc-ext, para cada cluster. Em cada cluster, você pode especificar sua própria configuração para esse serviço externo usandospec.clusterSpecList.externalConnectivity. Por exemplo, você pode alterar o tipo do serviço ou definir anotações.
Banco de Dados de Aplicativos. O Operador Kubernetes implementa o Banco de Dados de Aplicativo em dois clusters.
O
Member Cluster 1contém três processosmongodpara o Banco de Dados de Aplicativo e oMember Cluster 2contém dois processosmongod.Você define a configuração do banco de dados do aplicativo usando as configurações do
spec.applicationDatabase. Em cada cluster de membros, o Operador Kubernetes cria um StatefulSet denominado<om_resource_name>-db-<cluster_index>com o número de clusters de membros definidos emspec.applicationDatabase.clusterSpecList.members. No modo de vários clusters, o Operador Kubernetes ignora valores definidos para o campospec.applicationDatabase.members. O Operador Kubernetes configura um conjunto de réplicas formado a partir de processos domongoddistribuídos em todos os clusters de membros.Para cada Pod no
<statefulset_name>-<pod_index>hospedando um processo MongoDB denominado<om_resource_name>-db-<cluster_index>-<pod_index>, o Operador Kubernetes cria um KubernetesClusterIP-tipo de serviço para acessar os processos individuaismongodpor seu FQDN,<om_resource_name>-db-<cluster_index>-<pod_index>-svc. Cada processo domongodno conjunto de réplicas deve ser exclusivamente endereçável.Os processos na configuração do conjunto de réplicas devem ter seus nomes de host de processo configurados para o FQDN desse serviço de Pod :
<om_resource_name>-db-<cluster_index>-<pod_index>-svc.<namespace>.svc.cluster.local.Cada Pod tem seu volume persistente anexado por meio de uma Declaração de Volume Persistente que o Operador Kubernetes cria.
Para formar um conjunto de réplicas de todos os processos do
mongod, cada processo deve se conectar uns aos outros para fins de replicação. Para isso, inclua todos os clusters de membros nos quais você implementa o banco de dados de aplicativos na mesma configuração de malha de serviço.A mesclagem de serviço lida com queries de DNS entre clusters e roteia o tráfego adequadamente. A malha de serviços ajuda a resolver o FQDN
<om_resource_name>-db-<cluster_index>-<pod-index>-svc.<namespace>.svc.cluster.localde cada serviço de Pod em todos os clusters e permite a conectividade na portamongodexposta (27017 por padrão).Por exemplo, quando um processo
mongodem execução noom-db-1-0Pod emMember Cluster 1se conecta a ummongodem execução noom-db-2-1Pod emMember Cluster 2, o primeiro processomongodusa seu nome de host da Automação Configuration,om-db-2-1-svc.om-ns.svc.cluster.local:27017, e a malha de serviço encaminha essa solicitação paraMember Cluster 2para o serviçoom-db-2-1-svc. Sem a malha de serviços, o KubernetesMember Cluster 1não tem informações sobre o serviçoom-db-2-1-svcimplantado noMember Cluster 2e a resolução DNS doom-db-2-1-svc.om-ns.svc.cluster.localfalharia.Quando o Banco de Dados de Aplicativo e as instâncias do Aplicativo MongoDB Ops Manager estão em um estado
Running, o Operador Kubernetes adiciona um contêiner de monitoramento adicional ao Banco de Dados do Aplicativo StatefulSets. Isso resulta em uma reinicialização contínua de todos os Pods do Banco de Dados de Aplicativos em todos os clusters. O Operador Kubernetes atualiza os StatefulSets em todos os clusters sequencialmente, de modo que, durante o processo de reinicialização contínua , em cada cluster, apenas um membro do conjunto de réplicas fique temporariamente indisponível.O agente de monitoramento se conecta às MongoDB Ops Manager instâncias do MongoDB Ops Manager aplicativo usando o FQDN do serviço ,
<om_resource_name>-svc.<namespace>.svc.cluster.localou o valor em se vocêspec.opsManagerURLespecificá-lo.O Aplicativo MongoDB Ops Manager e o Backup Daemon sempre usam a connection string para o Banco de Dados do Aplicativo que contém todos os membros do conjunto de réplicas. A string de conexão é sempre construída usando os FQDNs de serviço por pod.
O Operador Kubernetes implementa o Backup Daemon StatefulSets se você definir o
spec.backup.enabledcomotrue.Em cada cluster de membros listado em
spec.clusterSpecList, o Operador Kubernetes cria um Backup Daemon StatefulSet, chamado<om_resource_name>-backup-daemon-<cluster_index>com o número de instâncias do Backup Daemon definidos comospec.backup.members.Como alternativa, você pode configurar o número de instâncias do Backup Daemon para cada cluster em
spec.clusterSpecList[*].backup.members.As instâncias do Backup Daemon se conectam somente ao conjunto de réplicas do banco de dados do aplicativo usando a mesma connection string que as instâncias do aplicativo MongoDB Ops Manager .
Além disso, neste diagrama, é possível observar a malha de serviço e as conexões de rede entre os componentes:
As linhas pontilhadas ao redor do diagrama mostram a única malha de serviço que inclui a configuração de rede para todos os clusters.
As linhas pontilhadas ao redor do aplicativo MongoDB Ops Manager nos clusters de membros indicam que essas instâncias não têm estado e o tráfego pode ser distribuído uniformemente para todas as instâncias, por exemplo , usando um balanceador de carga round-robin .
As linhas pontilhadas ao redor do banco de dados de aplicativos em clusters de membros indicam que essas instâncias se comunicam entre si e formam um único conjunto de réplicas MongoDB.