Configuração autogerenciada do conjunto de réplicas
Nesta página
Você pode acessar a configuração de um conjunto de réplicas utilizando o método rs.conf()
ou o comando replSetGetConfig
.
Para modificar a configuração de um conjunto de réplica, utilize o método rs.reconfig()
, passando um documento de configuração para o método. Consulte rs.reconfig()
para mais informações.
Aviso
Evite reconfigurar conjuntos de réplicas que contenham membros de diferentes versões do MongoDB, pois as regras de validação podem diferir entre as versões do MongoDB.
Exemplo de documento de configuração do conjunto de réplica
O documento a seguir fornece uma representação de um documento de configuração de conjunto de réplica. A configuração do seu conjunto de réplicas pode incluir somente um subconjunto dessas configurações:
{ _id: <string>, version: <int>, term: <int>, protocolVersion: <number>, writeConcernMajorityJournalDefault: <boolean>, configsvr: <boolean>, members: [ { _id: <int>, host: <string>, arbiterOnly: <boolean>, buildIndexes: <boolean>, hidden: <boolean>, priority: <number>, tags: <document>, secondaryDelaySecs: <int>, votes: <number> }, ... ], settings: { chainingAllowed : <boolean>, heartbeatIntervalMillis : <int>, heartbeatTimeoutSecs: <int>, electionTimeoutMillis : <int>, catchUpTimeoutMillis : <int>, getLastErrorModes : <document>, getLastErrorDefaults : <document>, replicaSetId: <ObjectId> } }
Campos de configuração do conjunto de réplicas
_id
Tipo: string
O nome do conjunto de réplicas.
_id
deve ser idêntico aoreplication.replSetName
ou ao valor de--replSet
especificado paramongod
na linha de comando.Dica
Consulte:
replSetName
ou--replSet
para informações sobre como configurar o nome do conjunto de réplicas.
version
Tipo: int
Um número incremental usado para distinguir as revisões do documento de configuração do conjunto de réplicas das iterações anteriores da configuração.
Os nós do conjunto de réplicas utilizam
term
eversion
para obter consenso sobre a configuração de réplica "mais recente". Quando os nós comparam documentos de configuração de réplicas, o documento de configuração com oterm
maior é considerado o "mais novo". Seterm
for o mesmo ou estiver ausente, o documento de configuração com oversion
maior será considerado o "mais novo".
term
Tipo: int
Disponível apenas com featureCompatibilityVersion (FCV) "4.4" ou posterior.
Um número de incremento usado para distinguir as revisões do documento de configuração do conjunto de réplicas das iterações anteriores da configuração. O
term
de um documento de configuração corresponde ao termo primário do conjunto de réplicas que executou a reconfiguração. O primário aumenta seu termo cada vez que avança após vencer uma eleição. O primário ignora o campoterm
se definido explicitamente na operaçãoreplSetReconfig
.A emissão de uma reconfiguração de força remove o campo
term
. Quando o primário, em seguida, emitereplSetReconfig
sem força, ela define oterm
para seu próprio termo.Os nós do conjunto de réplicas utilizam
term
eversion
para obter consenso sobre a configuração de réplica "mais recente". Quando os nós comparam documentos de configuração de réplicas, o documento de configuração com oterm
maior é considerado o "mais novo". Seterm
for o mesmo ou estiver ausente, o documento de configuração com oversion
maior será considerado o "mais novo".
configsvr
Tipo: booleano
Padrão: false
Indica se o conjunto de réplica é utilizado para servidores de configuração de um cluster fragmentado. Configure para
true
se o conjunto de réplica for para servidores de configuração do cluster fragmentado.
protocolVersion
Tipo: número
Padrão: 1
O MongoDB oferece suporte apenas a
protocolVersion: 1
e não oferece mais suporte aprotocolVersion: 0
.
writeConcernMajorityJournalDefault
Tipo: booleano
Padrão: true
Determina o comportamento de
{ w: "majority" }
write concern se a write concern não especificar explicitamente a opção de diário j.A tabela a seguir lista os valores
writeConcernMajorityJournalDefault
e o comportamento{ w: "majority" }
associado:Valor{ w: "majority" }
Comportamentotrue
O MongoDB reconhece a operação de gravação após a maioria dos membros votantes ter escrito no diário em disco.
IMPORTANTE: Todos os membros votantes do conjunto de réplicas devem ser executados com registro em diário
writeConcernMajorityJournalDefault
quandotrue
estiver.Se qualquer membro votante de um conjunto de réplicas usar o mecanismo de armazenamento na memória, você deverá definir
writeConcernMajorityJournalDefault
comofalse
.Se qualquer membro de votação de um conjunto de réplica utilizar o mecanismo de armazenamento in-memory e o
writeConcernMajorityJournalDefault
fortrue
, as operações de gravação do"majority"
poderão falhar. Isso inclui operações que usam inerentemente"majority"
preocupação de gravação, como o comandoreplSetStepDown
, ou vários métodosmongosh
que, por padrão, usam"majority"
preocupação de gravação, como métodos de gerenciamento de usuários e métodos de gerenciamento de funções.A partir da versão 4.2 (e 4.0.13 e 3.6.14 ), se um membro do conjunto de réplicas usar o mecanismo de armazenamento na memória (com ou sem votação), mas o conjunto de réplicas tiver
writeConcernMajorityJournalDefault
definido como verdadeiro, o membro do conjunto de réplicas registrará um aviso de inicialização.false
O MongoDB reconhece a operação de gravação depois que a maioria dos membros votantes aplicou a operação na memória.
AVISO:
Se qualquer membro votante de um conjunto de réplicas usar o mecanismo de armazenamento na memória, você deverá definir
writeConcernMajorityJournalDefault
comofalse
.A partir da versão 4.2 (e 4.0.13 e 3.6.14 ), se um membro do conjunto de réplicas usar o mecanismo de armazenamento na memória (com ou sem votação), mas o conjunto de réplicas tiver
writeConcernMajorityJournalDefault
definido como verdadeiro, o membro do conjunto de réplicas registrará um aviso de inicialização.Não é possível executar transações em um cluster fragmentado que tenha um shard com
writeConcernMajorityJournalDefault
definido comofalse
(como um shard com um membro votante que usa o mecanismo de armazenamento na memória).
members
members
Tipo: array
Uma array de documentos de configuração de nós, um para cada nó do conjunto de réplicas. A array
members
é uma array indexada a zero.Cada documento de configuração específico do membro pode conter os seguintes campos:
members[n]._id
Tipo: inteiro
Um identificador inteiro para o membro no conjunto de réplica, único entre todos os membros.
A partir do MongoDB 5.0, os valores podem ser qualquer valor inteiro maior ou igual a
0
. Anteriormente, esse valor era limitado a um inteiro entre0
e255
inclusive.Cada nó do conjunto de réplicas deve ter um único
_id
. Evite reutilizar valores do_id
mesmo que nenhuma entrada domembers[n]
esteja utilizando este_id
na configuração atual.Após configurar, você não poderá alterar o
_id
de um nó.Observação
Ao atualizar o objeto de configuração da réplica, acesse os nós do conjunto de réplicas na array
members
com o índice da array. O índice da array começa com0
. Não confunda esse valor de índice com o valor do campomembers[n]._id
em cada documento da arraymembers
.
members[n].host
Tipo: string
O nome do host e, se especificado, o número da porta do membro configurado.
O nome do host deve ser resolvido para cada host no conjunto de réplica.
Aviso
members[n].host
não pode conter um valor que produzalocalhost
ou a interface local, a menos que todos os nós do conjunto estejam em hosts que produzamlocalhost
.
members[n].arbiterOnly
Opcional.
Tipo: booleano
Padrão: false
Um booleano que identifica um árbitro. Um valor de
true
indica que o membro é um árbitro.Ao utilizar o método
rs.addArb()
para adicionar um árbitro, o método define automaticamentemembers[n].arbiterOnly
comotrue
no nó adicionado.
members[n].buildIndexes
Opcional.
Tipo: booleano
Padrão: true
Um booleano que indica se o
mongod
cria índices nesse nó. Você só pode definir esse valor ao adicionar um nó a um conjunto de réplicas. Não é possível alterar o campomembers[n].buildIndexes
depois que o nó tiver sido adicionado ao conjunto. Para adicionar um nó, consulters.add()
ers.reconfig()
.Não configure para
false
para instâncias domongod
que recebem queries de clientes.Configurar
buildIndexes
parafalse
pode ser útil se todas as seguintes condições forem verdadeiras:você só está usando essa instância para executar backups usando
mongodump
eeste membro não receberá queries e
a criação e a manutenção de índices sobrecarregam o sistema hospedeiro.
Mesmo se definido como
false
, os secundários criarão índices no campo_id
para facilitar as operações necessárias para replicação.Aviso
Se você definir
members[n].buildIndexes
comofalse
, também deverá definirmembers[n].priority
como0
. Semembers[n].priority
não for0
, o MongoDB retornará um erro ao tentar adicionar um nó commembers[n].buildIndexes
igual afalse
.Para garantir que o membro não receba nenhuma query, você deve criar todas as instâncias que não construam índices ocultos.
Outros segundários não podem replicar de um membro onde
members[n].buildIndexes
é falso.
members[n].hidden
Opcional.
Tipo: booleano
Padrão: false
Quando este valor é
true
, o conjunto de réplica oculta esta instância e não inclui o membro na saída dedb.hello()
ouhello
. Isso evita operações de leitura (ou seja, queries) de chegar a esse host por meio de preferência de leiturasecundária.Os nós ocultos podem reconhecer operações de gravação emitidas com a preocupação de gravação. Nas operações de gravação emitidas com a preocupação de gravação
"majority"
, o nó também deve ser um nó votante (p. ex.,votes
é maior que0
).
members[n].priority
Opcional.
Tipo: Número entre 0 e 1000 para primário/secundário; 0 ou 1 para árbitros.
Padrão: 1.0 para primário/secundário; 0 para árbitros.
Um número que indica a probabilidade relativa de um membro do conjunto de réplicas se tornar o primário.
Para aumentar a probabilidade de um membro se tornar o principal, especifique um valor
priority
maior para este membro.Para diminuir a probabilidade de um membro se tornar o primário, especifique um valor menor de
priority
para esse membro.
Alterar a prioridade de um membro aciona uma ou mais eleições. O algoritmo de eleição faz o melhor esforço possível para eleger o membro de maior prioridade como primário. No entanto, um membro de prioridade mais baixa pode se tornar o primário mesmo que um secundário de prioridade mais alta esteja disponível.
Se um membro de menor prioridade se tornar o primário, o servidor continuará convocando eleições periodicamente até que o membro do conjunto de réplicas de maior prioridade seja o primário. A frequência com que as eleições ocorrem depende da diferença de prioridade entre o membro eleito e o membro de maior prioridade.
Um membro com prioridade de
0
não pode se tornar o principal.Os nós sem direito a voto (ou seja, nós que têm
votes
definido como0
) devem ter uma prioridade de0
.
members[n].tags
Opcional.
Tipo: document
Padrão: nenhum
Um documento
tags
contém um campo de tag definido pelo usuário e pares de valores para o membro do conjunto de réplica.{ "<tag1>": "<string1>", "<tag2>": "<string2>",... } Para operações de leitura, você pode especificar um conjunto de tags na preferência de leitura para direcionar as operações para membros do conjunto de réplicas com as tags especificadas.
Nas operações de gravação, você pode criar uma preocupação de gravação personalizada usando
settings.getLastErrorModes
esettings.getLastErrorDefaults
.
Para obter mais informações, consulte Configurar conjuntos de tags de conjunto de réplica.
members[n].secondaryDelaySecs
Opcional.
Tipo: inteiro
Padrão: 0
O número de segundos "atrás" do primário que esse membro do set deve "atrasar".
Use esta opção para criar membros atrasados. Membros atrasados mantêm uma cópia dos dados que reflete o estado dos dados em algum momento no passado.
Os nós atrasados podem contribuir para o reconhecimento de operações de gravação emitidas com a preocupação de gravação. No entanto, eles não retornam a confirmação de gravação antes do valor de atraso configurado. Para operações de gravação emitidas com a preocupação de gravação
"majority"
, o nó também deve ser um nó votante (ou seja,votes
é maior que0
).
members[n].votes
Opcional.
Tipo: inteiro
Padrão: 1
O número de votos que um servidor lançará em uma eleição de conjunto de réplica. O número de votos que cada membro tem é
1
ou0
, e árbitros sempre têm exatamente1
voto.Nós com
priority
maior que 0 não podem ter 0votes
.Um conjunto de réplicas pode ter até 50 nós, mas apenas 7 nós votantes. Se você precisar de mais de 7 nós em um conjunto de réplicas, defina
members[n].votes
como0
para os nós adicionais sem direito a voto.Os nós não votantes (ou seja,
votes
é0
) devem terpriority
ou 0.A partir do MongoDB 5.0, um secundário recém-adicionado não conta como um membro votante e não pode ser eleito até que tenha atingido o estado
SECONDARY
.Membros sem direito a voto não podem reconhecer as operações de gravação emitidas com a write concern
"majority"
.
settings
settings
Opcional.
Tipo: document
Um documento que contém opções de configuração que se aplicam a todo o conjunto de réplicas.
O documento
settings
contém os seguintes campos:settings.chainingAllowed
Opcional.
Tipo: booleano
Padrão: true
No MongoDB 5.0.1 e versões anteriores, se
settings.chainingAllowed
for:true
, os membros secundários do conjunto de réplica podem replicar dados de outros membros secundários.false
, os membros secundários podem replicar os dados somente do principal.
A partir do MongoDB 5.0.2:
Os nós secundários do conjunto de réplicas podem replicar dados de outros nós secundários, mesmo que
settings.chainingAllowed
sejafalse
.Para substituir
settings.chainingAllowed
, defina o parâmetro do servidorenableOverrideClusterChainingSetting
comotrue
.O padrão para
enableOverrideClusterChainingSetting
éfalse
.
settings.getLastErrorDefaults
Opcional.
Tipo: document
Indisponível a partir do MongoDB 5.0.
Importante
A partir do MongoDB 5.0, você não pode especificar uma preocupação de gravação padrão com
settings.getLastErrorDefaults
diferente do padrão{ w: 1, wtimeout: 0 }
. Em vez disso, use o comandosetDefaultRWConcern
para definir a configuração padrão de preocupação de leitura ou gravação para um conjunto de réplicas ou cluster fragmentado.
settings.getLastErrorModes
Opcional.
Tipo: document
Um documento usado para definir uma preocupação de gravação personalizada por meio do uso de
members[n].tags
. A preocupação de gravação personalizada pode fornecer reconhecimento de data center.{ getLastErrorModes: { <name of write concern> : { <tag1>: <number>, .... }, ... } } O
<number>
se refere ao número de valores de tag diferentes necessários para satisfazer a preocupação de gravação. Por exemplo, o seguintesettings.getLastErrorModes
define uma preocupação de gravação denominadadatacenter
que exige que a gravação se propague para dois nós cujos valores de tagdc
diferem.{ getLastErrorModes: { datacenter: { "dc": 2 } } } Para usar a write concern personalizada, passe o nome da write concern para a opção
w
, por exemplo.{ w: "datacenter" } Consulte Configurar conjuntos de tags de conjunto de réplica para obter mais informações e exemplos.
settings.heartbeatTimeoutSecs
Opcional.
Tipo: int
Padrão: 10
Número de segundos que os membros do conjunto de réplica esperam por uma pulsação bem-sucedida uns dos outros. Se um membro não responder a tempo, outros membros marcarão o membro delinquente como inacessível.
settings.electionTimeoutMillis
Opcional.
Tipo: int
Padrão: 10000 (10 segundos)
O limite de tempo em milésimos de segundo para detectar quando o primário de um conjunto de réplicas não está acessível. Essa configuração controla a sensibilidade ao failover ao usar
protocolVersion: 1
. Espera-se que o tempo limite de failover não exceda o valor deelectionTimeoutMillis
.Considere o seguinte ao selecionar um valor:
Valores mais altos resultam em failovers mais lentos, mas diminuem a sensibilidade à lentidão ou irregularidade do nó primário ou da rede.
Valores mais baixos resultam em failover mais rápido, mas maior sensibilidade ao nó primário ou à lentidão ou à fragmentação da rede.
A configuração só se aplica ao usar
protocolVersion: 1
.Observação
Quando você desiste de uma primário usando
rs.stepDown()
oureplSetStepDown
sem definir o campoforce
comotrue
, a primário reduzida indica um secundário elegível para convocar uma eleição imediatamente.
settings.catchUpTimeoutMillis
Opcional.
Tipo: int
Padrão: -1, tempo de recuperação infinito.
Limite de tempo, em milésimos de segundo, para que um primário recém-eleito sincronize (recupere o atraso) com os outros membros do conjunto de réplicas que podem ter gravações mais recentes. Limites de tempo infinitos ou altos podem reduzir a quantidade de dados que os outros membros precisariam reverter após uma eleição, mas podem aumentar o tempo de failover.
A primário recém-eleita termina o período de recuperação mais cedo, uma vez que é totalmente alcançada com outros membros do conjunto. Durante o período de recuperação, um primário recém-eleito não está disponível para escritas de clientes. Use
replSetAbortPrimaryCatchUp
para abortar a recuperação e, em seguida, concluir a transição para a primária.A configuração só se aplica ao usar
protocolVersion: 1
.
settings.catchUpTakeoverDelayMillis
Opcional.
Tipo: int
Padrão: 30000 (30 segundos)
Tempo, em milésimos de segundo, que um nó aguarda para iniciar uma catchup takeover após determinar que está à frente do primário atual. Durante um catchup takeover, o nó à frente do primário atual inicia uma eleição para se tornar o novo primário do conjunto de réplicas.
Depois que o nó que inicia a aquisição determina que está à frente do primário atual, ele espera o número especificado de milésimos de segundo e, em seguida, verifica o seguinte:
Ainda está à frente do current primário,
É o nó mais atualizado entre todos os nós disponíveis,
O primário atual está alcançando isso.
Depois de determinar que todas essas condições foram atendidas, o nodo que inicia a aquisição imediatamente concorre às eleições.
Para obter mais informações sobre as Eleições do Conjunto de Réplica, consulte Eleições do Conjunto de Réplica.
Observação
A definição de
catchUpTakeoverDelayMillis
como-1
desativa a aquisição de catchup. DefinircatchUpTimeoutMillis
como0
desativa o catchup do primário e, consequentemente, também o controle do catchup.
settings.heartbeatIntervalMillis
Somente para uso interno.
A frequência em milésimos de segundo das batidas cardíacas.
settings.replicaSetId
Tipo: ObjectId
O ObjectId associado ao conjunto de réplicas e criado automaticamente durante
rs.initiate()
oureplSetInitiate
. Você não pode alterar oreplicaSetId
.