Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
Click here >
Docs Menu
Docs Home
/ /
/ / /

Convertir un set de réplicas en un clúster con un servidor de configuración integrado

A partir de MongoDB 8.0, puedes configurar un servidor de configuración para almacenar los datos de tu aplicación, además de los habituales clúster particionado metadata. Un servidor de configuración que almacena datos de aplicaciones se denomina partición de configuración o servidor de configuración incrustado.

Convertir tu set de réplicas en un clúster con un servidor de configuración embebido puede reducir:

  • El número de nodos requeridos en su implementación.

  • Complejidad para mantener clústeres de una sola partición.

No se puede convertir directamente un set de réplicas en una partición de configuración. Para convertir un set de réplicas en un servidor de configuración embebido, debes:

Si el control de acceso está habilitado, el comando transitionFromDedicatedConfigServer requiere la acción de autorización transitionFromDedicatedConfigServer para la clúster.

El rol clusterManager tiene la acción de autorización transitionFromDedicatedConfigServer y puede asignarse a un usuario.

El siguiente ejemplo convierte un conjunto de réplicas autoadministrado en una partición de configuración que contiene datos de usuario preexistentes del conjunto de réplicas.

1

Este tutorial supone que sabes cómo convertir tu set de réplicas autogestionado en un clúster. Para ver las instrucciones completas, consulta Convertir un set de réplicas autogestionado en un clúster.

2

Por ejemplo, para conectarse a su instancia de mongos que se ejecuta en el host mongodb6.example.net como un usuario administrador llamado admin01:

mongosh "mongodb://admin01@mongodb6.example.net:27017"
3

Para configurar su servidor de configuración dedicado para que funcione como una partición de configuración, ejecute el comando transitionFromDedicatedConfigServer desde la base de datos admin:

db.adminCommand( {
transitionFromDedicatedConfigServer: 1
} )
4

Para confirmar que un clúster utiliza una partición de configuración, ejecuta el comando listShards en la base de datos admin mientras estás conectado a un mongos e inspecciona la salida en busca de un documento donde _id esté configurado en "config". Si la salida de listShards no contiene un documento donde _id esté configurado en "config", el clúster no utiliza una partición de configuración.

El siguiente ejemplo ejecuta el comando listShards e intenta encontrar un documento donde _id esté establecido en "config".

db.adminCommand({ listShards: 1 })["shards"].find(element => element._id === "config")

En este ejemplo, el documento devuelto tiene _id asignado a "config", lo que confirma que este clúster utiliza una partición de configuración.

{
_id: "config",
host: "configRepl/localhost:27018",
state: 1,
topologyTime: Timestamp({ t: 1732218671, i: 13 }),
replSetConfigVersion: Long('-1')
}

Nota

Si el balanceador está en funcionamiento, migra automáticamente los datos entre las particiones. De lo contrario, utiliza los comandos moveCollection o moveChunk para distribuir tus datos manualmente.

5

Para reducir el clúster a una única partición después de añadir la partición de configuración, mueve todas las colecciones sin sharding a la partición de configuración usando el comando moveCollection y remueve la primera partición en el clúster con el comando removeShard. Este paso reduce tu clúster a una única partición de configuración.

Para obtener instrucciones completas sobre cómo remover particiones en su clúster, consulte Remover particiones de un clúster.

Volver

partición de configuración

En esta página