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.
Antes de tentar fazer um downgrade, familiarize-se com o conteúdo nesta página.
Caminho de downgrade
Importante
Antes de atualizar ou fazer downgrade de um cluster fragmentado, certifique-se de que todos os membros do cluster fragmentado estejam em execução. Se você não fizer isso, a atualização ou downgrade não será concluído até que todos os membros sejam iniciados.
Se você precisar fazer o downgrade do 8.3, faça o downgrade para a versão de correção mais recente do 8.0.
O MongoDB suporta downgrades de versão única apenas em versões adjacentes. Você não pode fazer o downgrade para uma versão que esteja várias versões atrás da versão atual.
Para qualquer versão, principal ou secundária, você pode atualizar ou fazer downgrade para seus vizinhos adjacentes. Por exemplo, você pode fazer downgrade de 8.3 para 8.2 ou atualizar de 7.0 para 8.0.
Para todas as versões, principais ou secundárias, você pode fazer downgrade para a versão principal imediatamente anterior. Por exemplo, de 8.3 a 8.0.
Para qualquer versão secundária, você pode atualizar para a versão imediatamente seguinte. Por exemplo, de 8.2 a 8.3.
Pré-requisitos
Antes de iniciar o procedimento de downgrade, você deve concluir as etapas de pré-requisito a seguir.
Criar cópia de segurança
Opcional, mas recomendado. Crie uma cópia de segurança do seu banco de dados.
Para saber como criar uma cópia de segurança, consulte Métodos de cópia de segurança para um sistema autogerenciado.
Remover recursos incompatíveis do Backward-Incompatible
Para fazer o downgrade 8.3 de 8.0 para, você deve remover 8.3 funcionalidades que são incompatíveis 8.0 com. Para obter uma lista de recursos incompatíveis e como removê-los, consulte Considerações sobre downgrade.
Certifique-se de que nenhuma operação de refragmentação esteja em andamento
Certifique-se de que todas as operações de refragmentação tenham sido concluídas com êxito. Se uma operação recente de refragmentação falhar devido a um failover primary, você deverá primeiro executar o comando cleanupReshardCollection antes de fazer downgrade do featureCompatibilityVersion do cluster fragmentado.
Se uma operação de refragmentação ainda estiver em execução enquanto você faz downgrade do featureCompatibilityVersion do cluster fragmentado, a operação de refragmentação não será concluída.
Downgrade Feature Compatibility Version (fCV)
Para fazer downgrade do FCV do seu cluster fragmentado:
Certifique-se de que não haja initial sync em andamento. A execução do comando
setFeatureCompatibilityVersionenquanto uma initial sync está em andamento faz com que a initial sync seja reiniciada.Certifique-se de que nenhum nó tenha um campo
newlyAddedna configuração do conjunto de réplicas. Execute o seguinte comando em cada nó do seu conjunto de réplicas para verificar isso:use local db.system.replset.find( { "members.newlyAdded" : { $exists : true } } ); O campo
newlyAddedsó aparece no documento de configuração do conjunto de réplicas de um nó durante e logo após uma sincronização inicial.Certifique-se de que nenhum membro do conjunto de réplicas esteja no estado
ROLLBACKouRECOVERING.Faça o downgrade de
featureCompatibilityVersionpara"8.0".Importante
Verifique se você removeu todas as funcionalidades incompatíveis com versões anteriores antes de fazer o downgrade da versão binária. Certifique-se de avaliar o caminho da atualização antes de continuar.
db.adminCommand( { setFeatureCompatibilityVersion: "8.0", confirm: true } ) O comando
setFeatureCompatibilityVersionexecuta gravações em uma coleção interna do sistema e é idempotente. Se o comando não for concluído com êxito, tente novamente o comando na instânciamongos.Observação
Solução de problemas
Enquanto
setFeatureCompatibilityVersionestiver em execução no cluster fragmentado, migrações, divisões e mesclagens de partes podem apresentar falhas comConflictingOperationInProgress.Se
setFeatureCompatibilityVersionfalhar com um erroManualInterventionRequirede o cluster tiver passado recentemente por uma operação de refragmentação que falhou devido a uma eleição, você deverá executar o comandocleanupReshardCollectionantes de tentar executarsetFeatureCompatibilityVersionnovamente.
Para garantir que todos os membros do conjunto de réplicas tenham o
featureCompatibilityVersionatualizado, conecte a cada membro do conjunto de réplicas e verifique ofeatureCompatibilityVersion:Dica
Controle de acesso
Para um cluster fragmentado que tenha o controle de acesso ativado, para executar o
adminCommandem um membro do conjunto de réplicas de fragmento, você deve se conectar ao membro como um usuário local do fragmento.db.adminCommand( { getParameter: 1, featureCompatibilityVersion: 1 } ) "featureCompatibilityVersion" : { "version" : "8.0" } Se algum membro retornar uma
featureCompatibilityVersionde"8.3", aguarde até que o membro retorne a versão"8.0"antes de continuar.
Para obter mais informações sobre o valor featureCompatibilityVersion retornado, consulte Obter FeatureCompatibilityVersion.
Procedimento de downgrade
Aviso
Antes de prosseguir com o procedimento de downgrade, certifique-se de que todos os membros do cluster fragmentado, inclusive os membros do conjunto de réplicas atrasadas, tenham as alterações de pré-requisito. Para fazer isso, verifique o featureCompatibilityVersion e remova as feições incompatíveis para cada nó antes de fazer o downgrade.
Baixe os binários 8.0 mais recentes
Utilizando um gerenciador de pacote ou um download manual, obtenha a versão mais recente do 8.0. Se estiver usando um gerenciador de pacote , adicione um novo repositório para os binários 8.0 e execute o processo de downgrade real.
Importante
Antes de atualizar ou fazer downgrade de um cluster, certifique-se de que todos os membros do cluster estejam em execução. Se você não fizer isso, a atualização ou downgrade não será concluído até que todos os membros sejam iniciados.
Se você precisar fazer o downgrade do 8.3, faça o downgrade para a versão de correção mais recente do 8.0.
Desabilitar o balancer
Para desabilitar o balanceador, conecte mongosh a uma instância mongos no cluster fragmentado e execute o seguinte comando:
sh.stopBalancer()
Observação
Se houver uma migração em andamento, o MongoDB concluirá a migração em andamento antes de encerrar o balancer. Para verificar o estado atual do balanceador, execute sh.isBalancerRunning().
Para verificar se o balanceador está desabilitado, execute o seguinte comando:
sh.getBalancerState()
sh.getBalancerState() retorna false se o balanceador estiver desabilitado.
Para obter mais informações sobre como desabilitar o balanceador, consulte Desabilitar o balanceador.
Faça o downgrade de cada shard, um de cada vez
Faça downgrade dos membros secundários do fragmento, um de cada vez.
Desligue o membro.
Para encerrar o processo
mongod, utilizemongoshpara se conectar à implantação e execute o seguinte comando:db.adminCommand( { shutdown: 1 } ) Reinicie o membro.
Para iniciar um processo do
mongod, execute o seguinte comando:mongod --dbpath </path-to-data-folder> Aguarde o membro entrar no estado
SECONDARY.Antes de fazer o downgrade do próximo secundário, aguarde até que o membro se recupere para o estado
SECONDARY. Para verificar o estado do membro, use o métodors.status()emmongosh.Repita as etapas anteriores para fazer downgrade de cada membro secundário.
Faça o downgrade do árbitro de shard, se houver.
Pule esta etapa se o conjunto de réplicas não incluir um árbitro.
Faça downgrade do membro árbitro do cluster fragmentado:
Desligue o membro.
Para desligar o árbitro, utilize
mongoshpara se conectar ao árbitro e execute o seguinte comando:db.adminCommand( { shutdown: 1 } ) Exclua o conteúdo da linguagem de definição de dados (DDL) do árbitro.
Para encontrar a linguagem de definição de dados (DDL) do árbitro
mongod, verifique a configuração dostorage.dbPathou a opção de linha de comando--dbpath.Execute o seguinte comando:
rm -rf /path/to/mongodb/datafiles/* Reinicie o árbitro.
Para iniciar um processo do
mongod, execute o seguinte comando:mongod --dbpath </path-to-mongodb-datafiles> Aguarde o membro entrar no estado
ARBITER.Antes de fazer o downgrade do primary, aguarde até que o nó se recupere para o estado
ARBITER. Para verificar o estado do membro, use o métodors.status()emmongosh.
Faça downgrade do fragmento primário.
Rebaixe o primário.
Em
mongosh, users.stepDown()para descer a primária e iniciar uma eleição para uma nova primária:rs.stepDown() Verifique se o primário foi desativado.
Execute o seguinte comando:
rs.status() Verifique se o primário foi desativado e se outro membro assume o estado
PRIMARY.Desligue o antigo membro primary.
Para desligar o antigo primário, conecte-se ao sistema usando
mongoshe execute o seguinte comando:db.adminCommand( { shutdown: 1 } ) Reinicie o
mongodcom o binário 8.0 .Para iniciar um processo do
mongod, execute o seguinte comando:mongod --dbpath </path-to-mongodb-datafiles> Repita para os shards restantes.
Faça o downgrade dos servidores de configuração
Faça o downgrade dos membros secundários do shard do conjunto de réplicas de servidores de configuração (CSRS) um de cada vez:
Desative o secundário.
Conecte-se ao secundário e execute o seguinte comando:
db.adminCommand( { shutdown: 1 } ) Reinicie o membro.
Para iniciar um processo do
mongod, execute o seguinte comando:mongod --dbpath </path-to-data-folder> Aguarde o membro entrar no estado
SECONDARY.Antes de fazer o downgrade do próximo secundário, aguarde até que o membro se recupere para o estado
SECONDARY. Para verificar o estado do membro, use o métodors.status()emmongosh.Repita as etapas anteriores para fazer downgrade de cada membro secundário.
Faça downgrade do servidor de configuração primário.
Rebaixe o primário.
Em
mongosh, executers.stepDown()para descer a primária e iniciar uma eleição para uma nova primária:rs.stepDown() Verifique se o primário foi desativado.
Execute o seguinte comando:
rs.status() Verifique se o primário foi desativado e se outro membro assume o estado
PRIMARY.Desligue o antigo membro primary.
Para desligar o antigo primário, conecte-se ao sistema usando
mongoshe execute o seguinte comando:db.adminCommand( { shutdown: 1 } ) Reinicie o
mongodcom o binário 8.0 .Para iniciar um processo do
mongod, execute o seguinte comando:mongod --dbpath </path-to-mongodb-datafiles>
Reative o balanceador
Após fazer o downgrade de todos os componentes do cluster fragmentado, conecte a um mongos e execute o seguinte comando para reativar o balanceador:
sh.startBalancer()
O método sh.startBalancer() também habilita a divisão automática para o cluster fragmentado.