Docs Menu
Docs Home
/ /

rotateCertificates (comando de base de datos)

Nuevo en la versión 5.0.

rotateCertificates

Gira el utilizado actualmente Certificados TLS para un mongod o para utilizar los valores actualizados para estos certificados definidos en el mongos archivode configuración.

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.

Nota

Atlas rota automáticamente los certificados. No es necesario ejecutar el comando rotateCertificates al usar Atlas. Use el comando rotateCertificates solo si desea rotar los certificados manualmente.

El comando tiene la siguiente sintaxis:

db.runCommand(
{
rotateCertificates: 1,
message: "<optional log message>"
}
)

El comando toma el siguiente campo opcional:

Parameter
Tipo
Descripción

message

string

opcional Un mensaje registrado por el servidor en el archivo de registro y en el archivo de auditoría.

El comando devuelve un documento con el siguiente rotateCertificates campo:

Campo
Tipo
Descripción

ok

bool

Contiene el estado de ejecución del comando. true en caso de éxito, o false si se produjo un error. Si false, también se proporciona un campo errmsg con un mensaje de error detallado.

La rotación incluye los siguientes certificados:

Para rotar uno o más de estos certificados:

  1. Se debe sustituir el certificado o los certificados que se desean rotar en el sistema de archivos, teniendo en cuenta las siguientes restricciones:

  2. Se debe conectar mongosh a mongod o a la instancia mongos en la que se desee realizar la rotación de certificados.

  3. Ejecute el comando para rotar los rotateCertificates mongod mongos certificados utilizados por la instancia o.

Cuando tiene lugar la rotación de certificados:

  • Las conexiones existentes a la instancia de mongod o mongos no se terminan y continuarán usando los certificados antiguos.

  • Cualquier nueva conexión utilizará los nuevos certificados.

Si ha configurado OCSP para su implementación, el comando rotateCertificates también obtendrá respuestas OCSP adjuntas durante la rotación.

El rotateCertificates comando se puede ejecutar en un o mongod mongos en ejecución independientemente del estado de replicación.

Solo se puede ejecutar una instancia de db.rotateCertificates() o rotateCertificates en cada mongod proceso o a la vez. Intentar iniciar una segunda instancia mientras una ya está en ejecución generará un error.mongos

Los archivos de certificado incorrectos, caducados, revocados o ausentes harán que falle la rotación del certificado, pero no invalidarán la configuración TLS existente ni terminarán el proceso mongod o mongos en ejecución.

Si el mongod o mongos está ejecutándose con --tlsCertificateSelector configurado en thumbprint, rotateCertificates fallará y guardará un mensaje de advertencia en la entrada de registro.

Tras una rotación correcta, los nombres de los sujetos, las huellas digitales y el periodo de validez de las huellas digitales de los certificados del servidor y del clúster se registran en el destino de registro configurado. Si la auditoría está habilitada, esta información también se escribe en el registro de auditoría.

En las plataformas Linux y Windows, si hay un, su huella digital y período de validez también se registran en estas CRL file ubicaciones.

Debe tener la rotateCertificates acción para usar el rotateCertificates comando. La acción rotateCertificates hostManager forma parte del rol.

La siguiente operación rota los certificados en una mongod instancia en ejecución, después de haber realizado las actualizaciones apropiadas en el archivo de configuración para especificar la información del certificado actualizada:

db.adminCommand( { rotateCertificates: 1 } )

Lo siguiente realiza lo mismo que lo anterior, pero también escribe un mensaje de registro personalizado en el momento de la rotación en el archivo de registro y en el archivo de auditoría:

db.adminCommand( { rotateCertificates: 1, message: "Rotating certificates" } )

Volver

renameCollection

En esta página