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
_idTipo: string
O nome do conjunto de réplicas.
_iddeve ser idêntico aoreplication.replSetNameou ao valor de--replSetespecificado paramongodna linha de comando.Dica
Consulte:
versionTipo: 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
termeversionpara 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 otermmaior é considerado o "mais novo". Setermfor o mesmo ou estiver ausente, o documento de configuração com oversionmaior será considerado o "mais novo".
termTipo: int
Disponível apenas com versão de compatibilidade do recurso (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
termde 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 campotermse 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, emitereplSetReconfigsem força, ela define otermpara seu próprio termo.Os nós do conjunto de réplicas utilizam
termeversionpara 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 otermmaior é considerado o "mais novo". Setermfor o mesmo ou estiver ausente, o documento de configuração com oversionmaior será considerado o "mais novo".
configsvrTipo: booleano
Padrão: false
Indica se o conjunto de réplica é utilizado para servidores de configuração de um cluster fragmentado. Configure para
truese o conjunto de réplica for para servidores de configuração do cluster fragmentado.
protocolVersionTipo: número
Padrão: 1
O MongoDB oferece suporte apenas a
protocolVersion: 1e não oferece mais suporte aprotocolVersion: 0.
writeConcernMajorityJournalDefaultTipo: 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
writeConcernMajorityJournalDefaulte 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
writeConcernMajorityJournalDefaultquandotrueestiver.Se qualquer membro votante de um conjunto de réplicas usar o mecanismo de armazenamento na memória, você deverá definir
writeConcernMajorityJournalDefaultcomofalse.Se qualquer membro de votação de um conjunto de réplica utilizar o mecanismo de armazenamento in-memory
writeConcernMajorityJournalDefaulte otruefor, as operações de"majority"gravação do poderão falhar. Isso inclui operações que usam inerentemente"majority"preocupação de gravação, como o comandoreplSetStepDown, ou vários métodosmongoshque, 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
writeConcernMajorityJournalDefaultdefinido 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
writeConcernMajorityJournalDefaultcomofalse.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
writeConcernMajorityJournalDefaultdefinido 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
writeConcernMajorityJournalDefaultdefinido comofalse(como um shard com um membro votante que usa o mecanismo de armazenamento na memória).
members
membersTipo: 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]._idTipo: 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 entre0e255inclusive.Cada nó do conjunto de réplicas deve ter um único
_id. Evite reutilizar valores do_idmesmo que nenhuma entrada domembers[n]esteja utilizando este_idna configuração atual.Após configurar, você não poderá alterar o
_idde 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
memberscom o índice da array. O índice da array começa com0. Não confunda esse valor de índice com o valor do campomembers[n]._idem cada documento da arraymembers.
members[n].hostTipo: 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].hostnão pode conter um valor que produzalocalhostou a interface local, a menos que todos os nós do conjunto estejam em hosts que produzamlocalhost.
members[n].arbiterOnlyOpcional.
Tipo: booleano
Padrão: false
Um booleano que identifica um árbitro. Um valor de
trueindica que o membro é um árbitro.Ao utilizar o método
rs.addArb()para adicionar um árbitro, o método define automaticamentemembers[n].arbiterOnlycomotrueno nó adicionado.
members[n].buildIndexesOpcional.
Tipo: booleano
Padrão: true
Um booleano que indica se o
mongodcria í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].buildIndexesdepois que o nó tiver sido adicionado ao conjunto. Para adicionar um nó, consulters.add()ers.reconfig().Não configure para
falsepara instâncias domongodque recebem queries de clientes.Configurar
buildIndexesparafalsepode ser útil se todas as seguintes condições forem verdadeiras:você só está usando essa instância para executar backups usando
mongodumpeeste 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_idpara facilitar as operações necessárias para replicação.Aviso
Se você definir
members[n].buildIndexescomofalse, também deverá definirmembers[n].prioritycomo0. Semembers[n].prioritynão for0, o MongoDB retornará um erro ao tentar adicionar um nó commembers[n].buildIndexesigual 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].hiddenOpcional.
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].priorityOpcional.
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
prioritymaior para este membro.Para diminuir a probabilidade de um membro se tornar o primário, especifique um valor menor de
prioritypara 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
0não pode se tornar o principal.Os nós sem direito a voto (ou seja, nós que têm
votesdefinido como0) devem ter uma prioridade de0.
members[n].tagsOpcional.
Tipo: document
Padrão: nenhum
Um documento
tagsconté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.getLastErrorModesesettings.getLastErrorDefaults.
Para obter mais informações, consulte Configurar conjuntos de tags de conjunto de réplica.
members[n].secondaryDelaySecsOpcional.
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].votesOpcional.
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 é
1ou0, e árbitros sempre têm exatamente1voto.Nós com
prioritymaior 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].votescomo0para os nós adicionais sem direito a voto.Os nós não votantes (ou seja,
votesé0) devem terpriorityou 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
settingsOpcional.
Tipo: document
Um documento que contém opções de configuração que se aplicam a todo o conjunto de réplicas.
O documento
settingscontém os seguintes campos:settings.chainingAllowedOpcional.
Tipo: booleano
Padrão: true
No MongoDB 5.0.1 e versões anteriores, se
settings.chainingAllowedfor: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:
Com uma substituição ativada, os membros secundários do conjunto de réplicas podem replicar dados de outros membros secundários, mesmo
settings.chainingAllowedquefalseseja.Para substituir
settings.chainingAllowede permitir a replicação de um membro secundário, defina o parâmetro do servidorenableOverrideClusterChainingSettingcomotrue.O padrão para
enableOverrideClusterChainingSettingéfalse.
settings.getLastErrorDefaultsOpcional.
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.getLastErrorDefaultsdiferente do padrão{ w: 1, wtimeout: 0 }. Em vez disso, use o comandosetDefaultRWConcernpara definir a configuração padrão de preocupação de leitura ou gravação para um conjunto de réplicas ou cluster fragmentado.
settings.getLastErrorModesOpcional.
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.getLastErrorModesdefine uma preocupação de gravação denominadadatacenterque exige que a gravação se propague para dois nós cujos valores de tagdcdiferem.{ 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.heartbeatTimeoutSecsOpcional.
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.electionTimeoutMillisOpcional.
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()oureplSetStepDownsem definir o campoforcecomotrue, a primário reduzida indica um secundário elegível para convocar uma eleição imediatamente.
settings.catchUpTimeoutMillisOpcional.
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
replSetAbortPrimaryCatchUppara 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.catchUpTakeoverDelayMillisOpcional.
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
catchUpTakeoverDelayMilliscomo-1desativa a aquisição de catchup. DefinircatchUpTimeoutMilliscomo0desativa o catchup do primário e, consequentemente, também o controle do catchup.
settings.heartbeatIntervalMillisSomente para uso interno.
A frequência em milésimos de segundo das batidas cardíacas.
settings.replicaSetIdTipo: ObjectId
O ObjectId associado ao conjunto de réplicas e criado automaticamente durante
rs.initiate()oureplSetInitiate. Você não pode alterar oreplicaSetId.