Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
Click here >
Menu Docs
Página inicial do Docs
/ /

setFeatureCompatibilityVersion (comando de banco de dados)

setFeatureCompatibilityVersion

Habilita ou desabilita os recursos que persistem aos dados incompatíveis com versões anteriores do MongoDB. Você só pode emitir o setFeatureCompatibilityVersion em relação ao banco de dados admin.

Aviso

Habilitar funcionalidades incompatíveis 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 funcionalidades incompatíveis com versões anteriores 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 esses recursos.

Esse comando está disponível em implantações hospedadas nos seguintes ambientes:

  • MongoDB Enterprise: a versão autogerenciada e baseada em assinatura do MongoDB

  • MongoDB Community: uma versão com código disponível, de uso gratuito e autogerenciada do MongoDB

Alterado na versão 8.3.

O comando tem a seguinte sintaxe:

db.adminCommand(
{
setFeatureCompatibilityVersion: <version>,
confirm: true,
writeConcern: { wtimeout: <timeout> },
dryRun: <boolean>
}
)

O comando setFeatureCompatibilityVersion usa os seguintes campos:

Obrigatório

Os valores possíveis para version são:

Versão
Descrição

"8.3"

Disponível no MongoDB 8.3 Sistemas

Habilita os 8.3 recursos que persistem dados incompatíveis com o MongoDB 8.2.

"8.2"

Disponível no MongoDB 8.2 e MongoDB 8.3 Implantações

A partir do MongoDB,8.3 você pode fazer downgrade do FCV "8.3" de "8.2" para.

"8.0"

Disponível no MongoDB 8.0 Sistemas

Habilita os 8.0 recursos que persistem dados incompatíveis com o MongoDB 7.0.

"7.0"

Disponível nos Sistemas do MongoDB 7.0

Habilita os recursos 7.0 que persistem dados incompatíveis como MongoDB 6.0.

Obrigatório

Novidades na versão 7.0.

Defina como true para confirmar a alteração da compatibilidade do recurso e permitir que a operação continue.

Se você omitir o parâmetro confirm ou definir confirm como um valor diferente de true, o comando falhará e retornará um aviso sobre a modificação da versão de compatibilidade do recurso.

Opcional

O writeConcern especifica o valor de preocupação de gravação wtimeout em milissegundos:

  • O período que o primary aguarda a confirmação da maioria dos nós do conjunto de réplicas. Se o reconhecimento não for recebido no período, a operação falhará.

  • O padrão é 60000 milissegundos. Utilize um período mais longo se os membros secundários do conjunto de réplicas tiverem um atraso que exceda o padrão wtimeout.

Observação

  • Para um standalone, execute o comando na instância do standalone mongod.

  • Para um conjunto de réplicas, execute o comando no primary. A maioria dos nós portadores de dados deve estar disponível.

  • Para um cluster fragmentado, execute o comando em uma instância do mongos.

Opcional

Se definido para true, o MongoDB simula uma atualização ou downgrade da versão de compatibilidade do recurso. Se o cluster contiver dados incompatíveis, a operação falhará com um erro.

Novidades na versão 8.3.

Se você precisar fazer downgrade da versão de compatibilidade dos recursos abaixo de 8.0, primeiro execute o comando transitionToDedicatedConfigServer . Para obter detalhes sobre o downgrade, consulte Versão de compatibilidade de recursos de downgrade.

Se você tentar atualizar o FCV de um cluster que contenha dados incompatíveis com encaminhamento na versão atualizada, receberá um CannotUpgrade erro. Dados incompatíveis com encaminhamento podem se referir a quaisquer dados em seu cluster que dependam de um recurso que foi removido na versão de destino.

Quando esse erro ocorre:

  • Modifique os dados do cluster para remover as funcionalidades incompatíveis com o encaminhamento e, em seguida, execute novamente o setFeatureCompatibilityVersion comando com a versão atualizada para definir o FCV para a versão atualizada.

  • Execute o setFeatureCompatibilityVersion comando com a versão original rebaixada para configurar o FCV de volta para a versão original.

    Importante

    A configuração do FCV para a versão original interrompe o procedimento de atualização e altera o FCV de volta para a versão rebaixada. Esse procedimento não redefine o cluster para o estado anterior ao início da atualização do FCV.

    Se a atualização do FCV confirmar que não há dados incompatíveis com o encaminhamento, mas parar ou falhar, qualquer tentativa subsequente de downgrade do FCV também falhará com uma mensagem de erro. Você deve concluir a atualização do FCV antes de tentar fazer o downgrade do FCV.

Se você tentar desatualizar o FCV de um cluster que contenha dados incompatíveis com versões anteriores na versão rebaixada, receberá um CannotDowngrade erro. Dados incompatíveis com versões anteriores podem se referir a quaisquer dados em seu cluster que dependam de um recurso que não esteja disponível na versão de destino.

Quando esse erro ocorre:

  • Modifique os dados do cluster para remover funcionalidades incompatíveis com versões anteriores e, em seguida, execute novamente o comando setFeatureCompatibilityVersion com a versão rebaixada para definir o fCV para a versão rebaixada.

  • Execute o comando setFeatureCompatibilityVersion com a versão atualizada original para configurar o fCV de volta para a versão original.

    Importante

    A configuração do fCV para a versão original interrompe o procedimento de downgrade e altera o fCV de volta para a versão atualizada. Esse procedimento não redefine o cluster de volta ao estado anterior ao início do downgrade do fCV.

    Se a desatualização do FCV confirmar que não há dados incompatíveis com versões anteriores, mas parar ou falhar, as tentativas subsequentes de atualização do FCV também falharão com uma mensagem de erro. Você deve concluir a desatualização do FCV antes de tentar atualizar o FCV.

A partir 8.3 de, você pode fazer downgrade do FCV do seu sistema para a versão secundária imediatamente anterior.

Para saber mais, consulte Downgrade 8.3 para 8.2.

Certas operações em segundo plano podem impedir a execução de setFeatureCompatibilityVersion. Utilize o currentOp para identificar quaisquer operações em andamento.

Se você acionar uma alteração de setFeatureCompatibilityVersion durante uma sincronização inicial, a sincronização poderá falhar com uma mensagem de erro OplogOperationUnsupported ao reproduzir entradas na fase de aplicação oplog. A sincronização após essa tentativa é bem-sucedida porque a fase de operação não repete mais a operação.

Implantações
featureCompatibilityVersion

Para o novo 8.3 sistemas

"8.3"

Para 8.3 sistemas do atualizados do 8.2

"8.2" até você setFeatureCompatibilityVersion "8.3"a.

Para o novo 8.0 sistemas

"8.0"

Para 8.0 sistemas do atualizados do 7.0

"7.0" até você setFeatureCompatibilityVersion "8.0"a.

Para novas implantações do 7.0

"7.0"

Para sistemas 7.0 atualizados do 6.0

"6.0" até você setFeatureCompatibilityVersion "7.0"a.

Este comando deve executar gravações em uma collection interna do sistema. Se, por algum motivo, o comando não for concluído com êxito, você poderá tentar novamente com segurança, pois a operação é idempotente.

A partir do MongoDB 6.0, se você precisar fazer downgrade da versão de compatibilidade de funcionalidades, certifique-se de desabilitar a replicação de cluster para cluster e o bloqueio de escrita do usuário.

  1. Se você ativou a replicação de cluster para cluster, desative-a.

  2. Se você habilitou o bloqueio de escrita do usuário, desative-o:

    db.runCommand( { setUserWriteBlockMode: 1, global: false } )
  3. Aguarde a conclusão do comando anterior.

  4. Faça downgrade da versão de compatibilidade de recursos usando setFeatureCompatibilityVersion.

Para obter mais informações sobre o MongoDB Cluster-to-Cluster Sync, consulte a documentação.

Os arbiters não replicam a collection admin.system.version. Por esse motivo, os arbiters sempre têm uma versão de compatibilidade de recursos igual à versão de downgrade do binário, independentemente do valor fCV do conjunto de réplicas.

Por exemplo, um árbitro em um cluster do MongoDB 5.0 tem um valor FCV de 4.4.

Para visualizar o featureCompatibilityVersion para uma instância do mongod, execute o comando getParameter em uma instância do mongod:

db.adminCommand(
{
getParameter: 1,
featureCompatibilityVersion: 1
}
)

A saída se assemelha a:

{
featureCompatibilityVersion: { version: '5.0' },
ok: 1,
'$clusterTime': {
clusterTime: Timestamp({ t: 1660318752, i: 5 }),
signature: {
hash: Binary(Buffer.from("ce0cff3621e9b089fa6d8e9a1e1efc1a1ff15dab", "hex"), 0),
keyId: Long("7129893797260951557")
}
},
operationTime: Timestamp({ t: 1660318752, i: 5 })
}

Observação

A operação é indefinida nas instâncias do mongos.

Em um cluster fragmentado com controle de acesso habilitado, você deve se conectar ao shard como um usuário local do shard para executar o comando.

Para habilitar as 8.0 funcionalidades do que persistem dados incompatíveis 7.0 com "8.0" o MongoDB, configure a compatibilidade da funcionalidade para no 8.0 sistema do MongoDB:

Observação

Execute o comando setFeatureCompatibilityVersion no banco de dados do admin.

  • Para um standalone, execute o comando na instância do standalone mongod.

  • Para um conjunto de réplicas, execute o comando no primary. A maioria dos nós portadores de dados deve estar disponível.

  • Para um cluster fragmentado, execute o comando em uma instância do mongos.

db.adminCommand(
{
setFeatureCompatibilityVersion: "8.0",
confirm: true
}
)

Para desabilitar as 8.0 funcionalidades do que persistem dados incompatíveis 7.0 com "7.0" o MongoDB, configure a compatibilidade da funcionalidade para no 8.0 sistema do MongoDB:

Observação

Execute o comando setFeatureCompatibilityVersion no banco de dados do admin.

  • Para um standalone, execute o comando na instância do standalone mongod.

  • Para um conjunto de réplicas, execute o comando no primary. A maioria dos nós portadores de dados deve estar disponível.

  • Para um cluster fragmentado, execute o comando em uma instância do mongos.

  • "7.0" featureCompatibilityVersion é suportado nos sistemas MongoDB 7.0 e MongoDB 8.0.

db.adminCommand(
{
setFeatureCompatibilityVersion: "7.0",
confirm: true
}
)

Se você executar esse comando como parte do processo de downgrade do MongoDB 8.0 para o MongoDB,7.0 também deverá remover todas as funcionalidades persistentes que são incompatíveis com. Consulte os 7.0 procedimentos de downgrade apropriados.

Para habilitar as funcionalidades do 7.0 que persistem dados incompatíveis com MongoDB 6.0, configure a compatibilidade da funcionalidade para "7.0" no sistema do MongoDB 7.0:

Observação

Execute o comando setFeatureCompatibilityVersion no banco de dados do admin.

  • Para um standalone, execute o comando na instância do standalone mongod.

  • Para um conjunto de réplicas, execute o comando no primary. A maioria dos nós portadores de dados deve estar disponível.

  • Para um cluster fragmentado, execute o comando em uma instância do mongos.

db.adminCommand(
{
setFeatureCompatibilityVersion: "7.0",
confirm: true
}
)

Para desabilitar as funcionalidades da versão 7.0 que persistem em dados incompatíveis com o MongoDB 6.0, defina a compatibilidade de funcionalidades como "6.0" no sistema do MongoDB 7.0:

Observação

Execute o comando setFeatureCompatibilityVersion no banco de dados do admin.

  • Para um standalone, execute o comando na instância do standalone mongod.

  • Para um conjunto de réplicas, execute o comando no primary. A maioria dos nós portadores de dados deve estar disponível.

  • Para um cluster fragmentado, execute o comando em uma instância do mongos.

  • "6.0" featureCompatibilityVersion é suportado somente nos sistemas MongoDB 6.0 e MongoDB 7.0.

db.adminCommand(
{
setFeatureCompatibilityVersion: "6.0",
confirm: true
}
)

Se executar como parte do processo de downgrade do MongoDB 7.0 para MongoDB 6.0, você também deverá remover todas as funcionalidades persistentes que são incompatíveis com o 6.0. Consulte os procedimentos de downgrade apropriados.

O exemplo a seguir define o campo de wtimeout de write concern opcional como 5000 (5 segundos).

Observação

Execute o comando setFeatureCompatibilityVersion no banco de dados do admin.

  • Para um standalone, execute o comando na instância do standalone mongod.

  • Para um conjunto de réplicas, execute o comando no primary. A maioria dos nós portadores de dados deve estar disponível.

  • Para um cluster fragmentado, execute o comando em uma instância do mongos.

db.adminCommand( {
setFeatureCompatibilityVersion: "5.0",
writeConcern: { wtimeout: 5000 }
} )

Voltar

setClusterParameter