shardingStateshardingStatees un comando de administrador que informa simongodes miembro de un clúster fragmentado. Para ejecutar el comando, debe ejecutarlo en laadminbase dedb.adminCommand()datos. Consulte.
Compatibilidad
Este comando está disponible en implementaciones alojadas en los siguientes entornos:
MongoDB Atlas: El servicio totalmente gestionado para implementaciones de MongoDB en la nube
Nota
Este comando es compatible con todos los clústeres de MongoDB Atlas. Para obtener información sobre el soporte de Atlas para todos los comandos, consulte Comandos no compatibles.
MongoDB Enterprise: La versión basada en suscripción y autogestionada de MongoDB
MongoDB Community: La versión de MongoDB con código fuente disponible, de uso gratuito y autogestionada.
Sintaxis
El comando tiene la siguiente sintaxis:
db.adminCommand( { shardingState: 1 } )
Comportamiento
Para que shardingState detecte que un es miembro de mongod mongod un clúster fragmentado, el debe satisfacer las siguientes condiciones:
el es un miembro principal de un conjunto de réplicas,
mongodyLa instancia es miembro de un clúster
mongodfragmentado.
Si detecta shardingState que un es miembro mongod shardingState de un clúster fragmentado, devuelve un documento que se parece al siguiente prototipo:
{ "enabled" : true, "configServer" : "<configdb-string>", "shardName" : "<string>", "shardHost" : "string:", "versions" : { "<database>.<collection>" : Timestamp(<...>), "<database>.<collection>" : Timestamp(<...>) }, "ok" : 1, "$clusterTime" : { "clusterTime" : Timestamp(1510716515, 1), "signature" : { "hash" : BinData(0,"B2ViX7XLzFLS5Fl9XEuFXbwKIM4="), "keyId" : Long("6488045157173166092") } }, "operationTime" : Timestamp(1510716515, 1) }
De lo contrario, devolverá el siguienteshardingState documento:
{ "enabled" : false, "ok" : 1, "$clusterTime" : { "clusterTime" : Timestamp(1510716515, 1), "signature" : { "hash" : BinData(0,"B2ViX7XLzFLS5Fl9XEuFXbwKIM4="), "keyId" : Long("6488045157173166092") } }, "operationTime" : Timestamp(1510716515, 1) }
La respuesta de cuando se shardingState utiliza con un servidor de configuración es:
{ "enabled" : false, "ok" : 1, "operationTime" : Timestamp(1510767613, 1), "$gleStats" : { "lastOpTime" : Timestamp(0, 0), "electionId" : ObjectId("7fffffff0000000000000001") }, "$clusterTime" : { "clusterTime" : Timestamp(1510767613, 1), "signature" : { "hash" : BinData(0,"IwBZ4SZjIMI5NdM62NObV/R31GM="), "keyId" : Long("6488693018630029321") } } }
Nota
mongos instancias no shardingState proporcionan.
Advertencia
Este comando obtiene un bloqueo de escritura en la base de datos afectada y bloqueará otras operaciones hasta que se complete; sin embargo, la operación suele tener una duración breve.