Importante
MongoDB 8.3 é a versão menor mais recente. A partir do MongoDB 8.2, versões secundárias estão disponíveis para implantações locais (Community e EA) para casos de uso específicos. Para mais informações, consulte Versão do MongoDB.
Para instalar a versão mais recente do MongoDB compatível com uso local, consulte as instruções de instalação.
Familiarize-se com o conteúdo deste documento, incluindo a revisão minuciosa dos pré-requisitos, antes de atualizar com o MongoDB 8.3.
As seguintes etapas esboçam o procedimento para atualizar um mongod que é um membro do shard da versão 8.0 para 8.3.
Se você precisar de orientação para atualizar para 8.3 o, os serviços profissionais do MongoDB oferecem suporte de atualização para ajudar a garantir uma transição tranquila, sem interrupção para seu aplicação MongoDB .
Recomendações de upgrade e listas de verificação
Ao atualizar, considere o seguinte:
Atualizar caminho da versão
Para atualizar uma implantação MongoDB existente para 8.3, você deve estar executando uma versão da série 8.0.
Ao atualizar de uma versão secundária, você deve atualizar sucessivamente as versões secundárias até ter atualizado para 8.3.
Para saber mais,consulte Atualizar 8.2 8.3para.
Verifique a compatibilidade do driver
Antes de fazer upgrade do MongoDB, verifique se você está usando um driver compatível com o MongoDB 8.3. Consulte a documentação do driver para seu driver específico para verificar a compatibilidade com o MongoDB 8.3.
As implementações atualizadas que são executadas em drivers incompatíveis podem encontrar comportamentos inesperados ou indefinidos.
Preparação
Antes de iniciar sua atualização, consulte o documento Alterações de compatibilidade no MongoDB 8.3 para garantir que seus aplicativos e sistemas sejam compatíveis com o MongoDB 8.3. Resolva as incompatibilidades em sua implantação antes de iniciar a atualização.
Antes de atualizar o MongoDB, sempre teste seu aplicativo em um ambiente de preparação antes de implantar a atualização em seu ambiente de produção.
Consideração de rebaixamento
A partir do MongoDB 8.3, você pode fazer downgrade da sua versão do MongoDB para a versão secundária ou principal imediatamente anterior.
O MongoDB suporta apenas downgrades de versão única. Você não pode fazer o downgrade para uma versão que esteja várias versões atrás da versão atual.
Por exemplo, você pode fazer downgrade de um 8.0 para um 7.0 sistema. No entanto, não há suporte para desatualização adicional dessa implantação 7.0 para uma implantação 6.0.
Para saber mais, consulte Downgrade 8.3 para 8.0.
Pré-requisitos
Versão de todos os membros
Para atualizar um cluster fragmentado 8.3 para, todos os membros do cluster devem ter pelo menos 8.0 a versão. O processo de atualização verifica todos os componentes do cluster e produz avisos se algum componente estiver executando uma versão anterior 8.0 a.
Versão de compatibilidade de recursos
O cluster fragmentado 8.0 deve ter featureCompatibilityVersion definido como "8.0".
Para garantir que todos os membros do cluster fragmentado tenham featureCompatibilityVersion configurado para "8.0", conecte a cada membro do conjunto de réplicas de shard e cada membro do conjunto de réplicas do servidor de configuração . Em seguida, verifique o featureCompatibilityVersion:
Dica
Para um cluster fragmentado que tenha o controle de acesso habilitado, para executar o seguinte comando em um nó do conjunto de réplicas do fragmento, você deve se conectar ao nó como um usuário local do fragmento.
db.adminCommand( { getParameter: 1, featureCompatibilityVersion: 1 } )
"featureCompatibilityVersion" : { "version" : "8.0" }
Para configurar ou atualizar featureCompatibilityVersion, execute o seguinte comando no mongos:
db.adminCommand( { setFeatureCompatibilityVersion: "8.0", confirm: true } )
Para mais informações, consulte setFeatureCompatibilityVersion.
Estado do membro do conjunto de réplicas
Para fragmentos e servidores de configuração, certifique-se de que nenhum nó do conjunto de réplicas esteja no estado ROLLBACK ou RECOVERING.
db.adminCommand( { replSetGetStatus: 1 } )
Faça backup do banco de dados config
Opcional, mas recomendado. Como precaução, crie um backup do banco de config dados do antes de atualizar o cluster fragmentado.
Download 8.3 Binários
Usar um gerenciador de pacotes
Se você instalou o MongoDB a partir dos repositórios MongoDB apt, yum, dnf ou zypper, deverá atualizar para a versão 8.3 utilizando seu gerenciador de pacotes.
Siga as instruções de instalação do8.3 apropriadas para seu sistema Linux. Isso requer adicionar um repositório para a nova versão e, em seguida, executar o processo de upgrade real.
Baixe manualmente os binários 8.3
Se você não tiver instalado o MongoDB usando um gerenciador de pacotes, poderá fazer o download manual dos binários do MongoDB no MongoDB Download Center.
Consulte as instruções de instalação da versão 8.3 para obter mais informações.
Procedimento de atualização
Desabilitar o Balanceador
Conecte o mongosh a uma instância do mongos no cluster fragmentado e execute o sh.stopBalancer() para desabilitar o balanceador:
sh.stopBalancer()
Observação
Se houver uma migração em andamento, o sistema a concluirá antes de encerrar o balanceador. Você pode executar o para verificar o estado atual do sh.isBalancerRunning() balanceador.
Para verificar se o balanceador está desativado, execute, que sh.getBalancerState() retorna false se o balanceador estiver desativado:
sh.getBalancerState()
Para obter mais informações sobre como desabilitar o balanceador, consulte Desabilitar o balanceador.
Atualize os servidores de configuração
Atualize os nós secundários do conjunto de réplicas, um de cada vez.
Desligue a instância secundária.
Para desligar o processo do
mongod, utilizemongoshpara se conectar ao membro do cluster e execute o seguinte comando:db.adminCommand( { shutdown: 1 } ) Substitua o 8.0 binário pelo 8.3 binário.
Iniciar o binário 8.3.
Inicie o binário 8.3 com o
--configsvr,--replSete--port. Inclua quaisquer outras opções conforme usado pela implantação.mongod --configsvr --replSet <replSetName> --port <port> --dbpath <path> --bind_ip localhost,<ip address> Se você usar um arquivo de configuração, atualize o arquivo para especificar,, e, então
sharding.clusterRole: configsvrreplication.replSetNamenet.portnet.bindIpinicie 8 o.3 binário:sharding: clusterRole: configsvr replication: replSetName: <string> net: port: <port> bindIp: localhost,<ip address> storage: dbpath: <path> Inclua quaisquer outras configurações conforme adequado para sua implantação.
Aguarde até que o membro se recupere para o estado
SECONDARYantes de atualizar o próximo membro secundário.Para verificar o estado do membro, emita
rs.status()emmongosh.
Reduza o conjunto de réplicas primário.
Conecte
mongoshao primário e users.stepDown()para reduzir o primário e forçar a eleição de um novo primário:rs.stepDown() Encerrar o primário de redução
Quando
rs.status()mostrar que o primário foi desativado e outro nó assumiu o estadoPRIMARY, encerre o primário desativado.Para encerrar o primário desativado, utilize
mongoshpara se conectar ao primário e executar o seguinte comando:db.adminCommand( { shutdown: 1 } ) Substitua o binário
mongodpelo binário 8.3 .Iniciar o binário 8.3.
Inicie o 8.3 com as opções
--configsvr,--replSet,--porte--bind_ip. Inclua quaisquer opções de linha de comando opcionais utilizadas pela implantação anterior:mongod --configsvr --replSet <replSetName> --port <port> --dbpath <path> --bind_ip localhost,<ip address> Se você usar um arquivo de configuração, atualize o arquivo para especificar,, e, então
sharding.clusterRole: configsvrreplication.replSetNamenet.portnet.bindIpinicie 8 o.3 binário:sharding: clusterRole: configsvr replication: replSetName: <string> net: port: <port> bindIp: localhost,<ip address> storage: dbpath: <path> Inclua qualquer outra configuração conforme adequado para sua implantação.
Atualize os shards
Atualize os fragmentos um de cada vez.
Para cada conjunto de réplicas do fragmento:
Atualize os nós secundários do conjunto de réplicas, um de cada vez.
Desligue a instância secundária.
Para desligar o processo do
mongod, utilizemongoshpara se conectar ao membro do cluster e execute o seguinte comando:db.adminCommand( { shutdown: 1 } ) Substitua o 8.0 binário pelo 8.3 binário.
Inicie o binário 8.3 com as opções
--shardsvr,--replSet,--porte--bind_ip. Inclua opções de linha de comando adicionais, conforme adequado, para sua implantação:mongod --shardsvr --replSet <replSetName> --port <port> --dbpath <path> --bind_ip localhost,<ip address> Se estiver usando um arquivo de configuração, atualize-o para incluir
sharding.clusterRole: shardsvr,replication.replSetName,net.portenet.bindIp, então inicie o binário 8.3 :sharding: clusterRole: shardsvr replication: replSetName: <string> net: port: <port> bindIp: localhost,<ip address> storage: dbpath: <path> Inclua qualquer outra configuração conforme adequado para sua implantação.
Aguarde até que o membro se recupere para o estado
SECONDARYantes de atualizar o próximo membro secundário.Para verificar o estado do membro, você pode emitir
rs.status()emmongosh.Repita para cada membro secundário.
Reduza o conjunto de réplicas primário.
Conecte
mongoshao primário e users.stepDown()para reduzir o primário e forçar a eleição de um novo primário:rs.stepDown() Atualize o primário desativado.
Quando
rs.status()mostrar que o primário foi desativado e outro membro assumiu o estadoPRIMARY, faça upgrade do primário desativado:Encerrar o primário de redução
Para encerrar o primário desativado, utilize
mongoshpara conectar ao membro do conjunto de réplicas e executar o seguinte comando:db.adminCommand( { shutdown: 1 } ) Substitua o binário
mongod. com o binário 8.3 .Iniciar o binário 8.3.
Inicie o binário 8.3 com as opções
--shardsvr,--replSet,--porte--bind_ip. Inclua opções de linha de comando adicionais, conforme adequado, para sua implantação:mongod --shardsvr --replSet <replSetName> --port <port> --dbpath <path> --bind_ip localhost,<ip address> Se estiver usando um arquivo de configuração, atualize o arquivo para especificar
sharding.clusterRole: shardsvr,replication.replSetName,net.portenet.bindIpe, em seguida, inicie o 8.3 binário:sharding: clusterRole: shardsvr replication: replSetName: <string> net: port: <port> bindIp: localhost,<ip address> storage: dbpath: <path> Inclua qualquer outra configuração conforme adequado para sua implantação.
Atualize as mongos instâncias de
Importante
Upgrade todas as instâncias do conjunto de réplicas do servidor de configuração (CSRS) primeiro, seguidas por todos os membros do fragmento e, finalmente, as instâncias mongos. Fazer upgrade do mongos antes de concluir estes upgrades pode resultar em problemas de compatibilidade.
Substitua cada instância mongos pelo 8.3 binário e reinicie. Inclua qualquer outra configuração conforme adequado para sua implantação.
Observação
A opção --bind_ip deve ser especificada quando os nós do cluster fragmentado são executados em hosts diferentes ou se clientes remotos se conectarem ao cluster fragmentado.
mongos --configdb csReplSet/<rsconfigsver1:port1>,<rsconfigsver2:port2>,<rsconfigsver3:port3> --bind_ip localhost,<ip address>
Reative o balanceador
Utilizando mongosh, conecte-se a um mongos no cluster e execute sh.startBalancer() para reativar o balanceador:
sh.startBalancer()
Para obter mais informações sobre como reativar o balanceador, consulte a página Habilitar o balanceador.
Habilitar funcionalidades 8.3 incompatíveis com versões anteriores
Neste ponto, você pode executar o 8.3 binários sem os recursos recursos do 8.3 que são incompatíveis com 8.0.
Para habilitar estas funcionalidades do 8.3, configure a versão de compatibilidade do recurso (FCV) para 8.3. Você também deve definir confirm como true.
Dica
Habilitar essas recursos funcionalidades com versões anteriores pode complicar o processo de downgrade, pois você deve remover todos as funcionalidades persistentes incompatíveis com versões anteriores antes de fazer o downgrade.
É recomendável que, após a atualização, você permita que seu sistema seja executado sem habilitar essas funcionalidades por um período de burn-in para garantir que a probabilidade de downgrade seja mínima. Quando você estiver confiante de que a probabilidade de downgrade é mínima, habilite essas funcionalidades.
Em uma instância do mongos, execute o comando setFeatureCompatibilityVersion no banco de dados admin:
db.adminCommand( { setFeatureCompatibilityVersion: "8.3", confirm: true } )
Definindo featureCompatibilityVersion (FCV) : "8.3" executa implicitamente um em cada replSetReconfig term shard para adicionar o campo ao documento de configuração de réplica do shard.
O comando não é concluído até que a nova configuração se propague para a maioria dos membros do conjunto de réplicas.
Este comando deve executar gravações em uma collection interna do sistema. Se o comando não for concluído, você poderá tentar novamente o comando no mongos com segurança, pois a operação é idempotente.
Observação
Enquanto setFeatureCompatibilityVersion estiver em execução no cluster fragmentado, migrações, divisões e mesclagens de partes podem apresentar falhas com ConflictingOperationInProgress.
O MongoDB limpa todos os documentos órfãos que existem em seus shards quando você define setFeatureCompatibilityVersion 8.3como. O processo de limpeza:
Não bloqueia a conclusão da atualização e
Tem limitação de taxa. Para mitigar o possível efeito no desempenho durante a limpeza de documentos órfãos, consulte Ajuste de desempenho de exclusão de intervalo.
Aviso
Compatibilidade mongos fCV
O binário mongos não pode se conectar a instâncias mongod cuja feature compatibility version (fCV) seja maior que a do mongos. Por exemplo, você não pode conectar um MongoDB 8.0 versão mongos a um 8.3 cluster fragmentado com fCV definido como 8.3. Entretanto, você pode conectar um MongoDB versão 8.0 mongos a um cluster fragmentado 8.3 com fCV definido como 8.0.
Procedimentos de atualização adicionais
Para atualizar um autônomo, consulte 8.0 Atualizar standalone 8.3 para.
Para atualizar um conjunto de réplicas, consulte Atualizar conjunto de réplicas 8.0 8.3 para.