Overview
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.
Procedimiento
Si estás realizando una de las operaciones anteriores, es necesario reconfigurar tu set de réplicas en dos pasos:
Reconfigura el set de réplicas para añadir o modificar un secundario con
{ votes: 1, priority: 0 }.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.
Agregar o modificar una secundaria con votos 1 pero prioridad 0
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);
Reconfigure el secundario para que tenga una prioridad distinta de cero
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);