Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

Modifica de manera segura un set de réplicas de PSA autogestionado

Al reconfigurar sets de réplicas primaria-secundaria-árbitro (PSA) o cambiar a una arquitectura PSA, debes tener especial cuidado en los siguientes casos:

  • Desea reconfigurar un secundario en un conjunto de réplicas existente de tres miembros con una arquitectura PSA para que se convierta en un nodo con voto y portador de datos con una prioridad distinta de cero.

  • Desea agregar un nuevo nodo de votación y portador de datos con una prioridad distinta de cero a un conjunto de réplicas existente de dos miembros que contiene un nodo principal y un árbitro.

Advertencia

Si el secundario que está agregando está retrasado y el conjunto de réplicas resultante es una configuración de PSA, el primer cambio de configuración cambiará la cantidad de nodos que necesitan confirmar un cambio con "majority"En este caso, su punto de confirmación quedará rezagado hasta que el secundario lo alcance.

Este documento describe el procedimiento para reconfigurar su conjunto de réplicas en estos casos específicos sin utilizar el método auxiliar rs.reconfigForPSASet() designado.

Si estás realizando una de las operaciones anteriores, es necesario reconfigurar tu set de réplicas en dos pasos:

  1. Reconfigura el set de réplicas para añadir o modificar un secundario con { votes: 1, priority: 0 }.

  2. Una vez que el secundario añadido o modificado esté al día con todos los guardados confirmados, se debe reconfigurar el secundario para que tenga una prioridad distinta de cero { votes: 1, priority: <num> }.

El enfoque de dos pasos evita la posibilidad de revertir escrituras confirmadas en el caso de una conmutación por error al nuevo secundario antes de que este tenga todas las escrituras confirmadas del primario anterior.

Para ejecutar el rs.reconfigForPSASet() método, debes conectarte al primario del set de réplicas.

1

Para evitar revertir escrituras no confirmadas al agregar o cambiar un nodo con votación que contiene datos, es necesario que primero agregue el nodo con { priority: 0 }.

En mongosh, modifica la configuración del set de réplicas. Para reconfigurar un set de réplicas existente, primero recupera la configuración actual con rs.conf(), modifica el documento de configuración según sea necesario y, a continuación, pasa el documento modificado a rs.reconfig():

cfg = rs.conf();
cfg["members"] = [
{
// existing member or members
},
{
"_id" : <num>, // The array position of the new member in the
// ``members`` array.
"host" : <host>,
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 0,
"tags" : { <tags> },
"secondaryDelaySecs" : <num>,
"votes" : 1
},
{
// existing member or members
}
]
rs.reconfig(cfg);
2

Una vez que el secundario esté al día, establezca la prioridad en el número deseado. Antes de que esta reconfiguración tenga éxito, el secundario debe replicar todos los guardados que se confirmaron cuando tenía cero votos. Esta opción se marca automáticamente cuando emites el comando rs.reconfig().

cfg = rs.conf();
cfg["members"] = [
{
// existing member or members
},
{
"_id" : <num>, // The array position of the new member in the
// ``members`` array.
"host" : <host>,
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : <num>,
"tags" : { <tags> },
"secondaryDelaySecs" : <num>,
"votes" : 1
},
{
// existing member or members
}
]
rs.reconfig(cfg);

Volver

Cambiar el nombre de un set de réplicas

En esta página