Definir versão de compatibilidade do recurso
Definição
setFeatureCompatibilityVersion
Habilita ou desabilita as funcionalidades que persistem aos dados incompatíveis com versões anteriores do MongoDB. Você só pode enviar
setFeatureCompatibilityVersion
no banco de dadosadmin
.
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.
Compatibilidade
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
Sintaxe
O comando recebe o seguinte formulário:
db.adminCommand( { setFeatureCompatibilityVersion: <version>, writeConcern: { wtimeout: <timeout> } } )
Os valores para version
são:
Versão | Descrição |
---|---|
| Disponível no MongoDB 5.0 Sistemas Habilita os recursos 5.0 que persistem dados incompatíveis com o MongoDB 4.4. |
| Disponível nos Sistemas MongoDB 4.4 e 5.0 Habilita os 4.4 recursos que persistem dados incompatíveis com o MongoDB 4.2. |
| Disponível nos Sistemas do MongoDB 4.4 Desabilita as funcionalidades do 4.4 que persistem dados incompatíveis com MongoDB 4.2. |
writeConcern
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ãowtimeout
.
Comportamento
Conflitos com operações em background
Certas operações em segundo plano podem impedir a execução de setFeatureCompatibilityVersion
. Utilize o currentOp
para identificar quaisquer operações em andamento.
Falhas de sincronização
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.
Default Values
Implantações | featureCompatibilityVersion |
---|---|
Para novas implantações do 5.0 |
|
Para sistemas 5.0 atualizados do 4.4 |
|
Idempotência
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.
Compatibilidade de Funcionalidades em Arbiters
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 arbiter em um cluster do MongoDB 5.0 tem um valor fCV de 4.4.
Exemplos
Ver FeatureCompatibilityVersion
Para visualizar o featureCompatibilityVersion
para uma instância do mongod
, execute o seguinte comando em uma instância do mongod
:
Observação
A operação é indefinida nas instâncias do mongos
. Para um cluster fragmentado que tenha o controle de acesso ativado, para executar o comando em um membro do conjunto de réplicas de shard, você deve se conectar ao membro como um usuário local de shard.
db.adminCommand( { getParameter: 1, featureCompatibilityVersion: 1 } )
A saída deste comando será semelhante a uma das seguintes, dependendo do estado atual do mongod
:
Se a implantação tiver o padrão
featureCompatibilityVersion
ou se o comandosetFeatureCompatibilityVersion
tiver sido executado com êxito na implantação,featureCompatibilityVersion
terá o formato:"featureCompatibilityVersion" : { "version" : <version> } Se o
mongod
estiver em um estado parcialmente atualizado ou downgrade, ofeatureCompatibilityVersion
terá o seguinte formulário:"featureCompatibilityVersion" : { "version" : <version> , "targetVersion" : <target version> } Por exemplo, se um cluster fragmentado tiver um conjunto de réplicas de shard que é somente leitura quando você executar o comando
setFeatureCompatibilityVersion
nomongos
, o comando falhará e ofeatureCompatibilityVersion
dos servidores de configuração incluirá o campotargetVersion
.Ou, se um conjunto de réplicas se tornar somente leitura enquanto
setFeatureCompatibilityVersion
estiver em execução, o comando falhará e ofeatureCompatibilityVersion
do conjunto de réplicas também incluirá o campotargetVersion
.
Definir Versão de Compatibilidade de Funcionalidades nos Sistemas do MongoDB 5.0
Habilitar funcionalidades incompatíveis ao 5.0 para trás
Para habilitar as funcionalidades do 5.0 que persistem dados incompatíveis com MongoDB 4.4, configure a compatibilidade da funcionalidade para "5.0"
no sistema do MongoDB 5.0:
Observação
Execute o comando setFeatureCompatibilityVersion
no banco de dados do admin
.
db.adminCommand( { setFeatureCompatibilityVersion: "5.0" } )
Desabilitar funcionalidades incompatíveis com versões anteriores ao 5.0
Para desabilitar as funcionalidades do 5.0 que persistem dados incompatíveis com MongoDB 4.4, configure a compatibilidade da funcionalidade para "4.4"
no sistema do MongoDB 5.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
.
"4.4"
featureCompatibilityVersion é suportado somente nos sistemas MongoDB 4.4 e MongoDB 5.0.
db.adminCommand( { setFeatureCompatibilityVersion: "4.4" } )
Se executar como parte do processo de downgrade do MongoDB 5.0 para MongoDB 4.4, você também deverá remover todas as funcionalidades persistentes que são incompatíveis com o 4.4. Consulte os procedimentos de downgrade apropriados.
Definir Tempo Limite de Write Concern
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
.
db.adminCommand( { setFeatureCompatibilityVersion: "5.0", writeConcern: { wtimeout: 5000 } } )