Docs Menu
Docs Home
/ /

db.watch() (método mongosh)

db.watch( pipeline, options )

Solo para Sets de réplicas y clústeres fragmentados

Abre una Cambiar el cursor de flujo de una base de datos para informar sobre todas sussystem colecciones que no sean.

Parameter
Tipo
Descripción

pipeline

arreglo

Opcional. Una canalización de agregación que consiste en una o más de las siguientes etapas de agregación:

Especifica un pipeline para filtrar o modificar la salida de los eventos de cambio.

A partir de MongoDB 4.2, los flujos de cambios lanzarán una excepción si la pipeline de agregación de flujos de cambios modifica el campo _id de un evento.

options

Documento

Opcional. Opciones adicionales que modifican el comportamiento de db.watch().

El documento options puede contener los siguientes campos y valores:

Campo
Tipo
Descripción

resumeAfter

Documento

Opcional. Especifica un token de reanudación como punto de inicio lógico para el flujo de cambios. No se puede usar para reanudar el flujo de cambios después de un invalidate evento.

resumeAfter es mutuamente excluyente con startAfter y startAtOperationTime.

startAfter

Documento

Opcional. Especifica un token de reanudación como el punto de inicio lógico para el flujo de cambios. A diferencia de resumeAfter, startAfter puede reanudar las notificaciones después de un evento invalidate creando un nuevo flujo de cambios.

startAfter es mutuamente excluyente con resumeAfter y startAtOperationTime.

fullDocument

string

Opcional. Por defecto, db.watch() devuelve el delta de los campos que han sido modificados por una operación de actualización, en lugar de todo el documento actualizado.

Configura fullDocument en "updateLookup" para dirigir a db.watch() a buscar la versión más reciente del documento actualizado que haya sido comprometida por la mayoría. db.watch() devuelve un campo fullDocument con la búsqueda de documentos además del delta de updateDescription.

A partir de MongoDB 6.0, puede configurar fullDocument para:

  • "whenAvailable" para mostrar el documento después de la imagen, si está disponible, después de insertar, reemplazar o actualizar el documento.

  • "required" para generar la imagen del documento después de que se haya insertado, reemplazado o actualizado. Genera un error si la imagen de publicación no está disponible.

fullDocumentBeforeChange

string

Opcional. El valor por defecto es "off".

A partir de MongoDB 6.0, puede usar el nuevo campo fullDocumentBeforeChange y configurarlo en:

  • "whenAvailable" para mostrar la imagen anterior del documento, si está disponible, antes de que el documento sea reemplazado, actualizado o borrado.

  • "required" para mostrar la imagen previa del documento antes de que el documento fuera reemplazado, actualizado o borrado. Genera un error si la pre-imagen no está disponible.

  • "off" para suprimir la imagen anterior del documento. "off" es el valor por defecto.

batchSize

Int

Opcional. Especifica el número máximo de eventos de cambio que se devolverán en cada lote de la respuesta del clúster MongoDB.

Tiene la misma funcionalidad que cursor.batchSize().

maxAwaitTimeMS

Int

Opcional. El tiempo máximo en milisegundos que el servidor espera para que los nuevos cambios de datos se informen al cursor del flujo de cambios antes de devolver una agrupación vacía.

Se establece por defecto en 1000 milisegundos.

collation

Documento

Opcional. Pasa un documento de intercalación para especificar una intercalación para el cursor del flujo de cambios.

Si se omite, el valor predeterminado es la comparación binaria simple.

startAtOperationTime

Marca de tiempo

Opcional. El punto de inicio para el flujo de cambios. Si el punto de inicio especificado está en el pasado, debe encontrarse dentro del rango de tiempo del oplog. Para comprobar el rango temporal del oplog, consulta rs.printReplicationInfo().

startAtOperationTime es mutuamente excluyente con resumeAfter y startAfter.

Devuelve:Un cursor sobre los documentos de eventos de cambio. Consulte Eventos de cambio para ver ejemplos de documentos de eventos de cambio.

Tip

Este método 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.

db.watch() Está disponible para conjuntos de réplicas y clústeres fragmentados:

  • Para un set de réplicas, se puede emitir db.watch() en cualquier Nodo que contenga datos.

  • Para un clúster particionado, se debe emitir db.watch() en una instancia mongos.

Solo se puede usar db.watch() con el motor de almacenamiento WiredTiger.

A partir de MongoDB,4.2 losflujos de cambio están disponibles independientemente del "majority" soporte de lectura de preocupación; es decir, el soporte de lectura de majority preocupación puede estar habilitado (predeterminado) o deshabilitado para usar flujos de cambio.

En MongoDB 4.0 y versiones anteriores, losflujos de cambio solo están disponibles si "majority" el soporte de lectura de inquietudes está habilitado (predeterminado).

  • No puede ejecutar en db.watch() la admin local config base de datos, o.

  • db.watch() solo notifica a la mayoría de los miembros portadores de datos sobre cambios en los datos que han persistido.

  • El cursor de flujo de cambios permanece abierto hasta que ocurra una de las siguientes situaciones:

    • El cursor se cierra explícitamente.

    • Se produce un evento de invalidación; por ejemplo, un descarte o cambio de nombre de una colección.

    • La conexión a la implementación de MongoDB se cierra o se agota el tiempo de espera. Consulta Comportamiento para obtener más información.

    • Si la implementación es un clúster fragmentado, la eliminación de un fragmento puede provocar que se cierre un cursor de flujo de cambio abierto y que el cursor de flujo de cambio cerrado no pueda reanudarse por completo.

  • Puede ejecutar para una base de datos inexistente. Sin embargo, una vez creada y borrada la base de datos, el cursor del flujo de cambios se db.watch() cierra.

A diferencia de los controladores de MongoDB, mongosh no intenta automáticamente reanudar un cursor de flujo de cambios después de un error. Los controladores de MongoDB hacen un intento de reanudar automáticamente un cursor de flujo de cambios después de ciertos errores.

db.watch() utiliza la información almacenada en el oplog para generar la descripción del evento de cambio y crear un token de reanudación asociado a esa operación. Si la operación identificada por el token de reanudación pasado a la opción resumeAfter o startAfter ya ha salido del oplog, db.watch() no puede reanudar el flujo de cambios.

Consulte Reanudar un flujo de cambios para obtener más información sobre cómo reanudar un flujo de cambios.

Nota

  • No se puede usar resumeAfter para reanudar un flujo de cambios después de que un evento de invalidación (por ejemplo, un descarte o cambio de nombre de colección) cierre el flujo. En su lugar, se puede utilizar startAfter para iniciar un nuevo flujo de cambios después de un evento de invalidación.

  • Si la implementación es un clúster fragmentado, la eliminación de un fragmento puede provocar que se cierre un cursor de flujo de cambio abierto y que el cursor de flujo de cambio cerrado no pueda reanudarse por completo.

Nota

No se puede usar resumeAfter para reanudar un flujo de cambios después de que un evento de invalidación (por ejemplo, un descarte o cambio de nombre de colección) cierre el flujo. En su lugar, se puede utilizar startAfter para iniciar un nuevo flujo de cambios después de un evento de invalidación.

Por defecto, el cursor de flujo de cambios devuelve cambios/deltas específicos de campo para las operaciones de actualización. También puedes configurar el flujo de cambios para buscar y devolver la versión actual del documento modificado que ha sido comprometida por la mayoría. Dependiendo de otras operaciones de guardado que puedan haber ocurrido entre la actualización y la búsqueda, el documento devuelto puede diferir significativamente del documento en el momento de la actualización.

Dependiendo del número de cambios aplicados durante la operación de actualización y del tamaño del documento completo, existe el riesgo de que el tamaño del documento de evento de cambio para una operación de actualización sea mayor que el límite de 16 MB para documentos BSON. Si esto ocurre, el servidor cierra el cursor del flujo de cambios y devuelve un error.

Al ejecutar con control de acceso, el usuario debe tener los find privilegios y en el recurso de base de changeStream datos. Es decir, un usuario debe tener un rol que otorgue el siguiente privilegio:

{ resource: { db: <dbname>, collection: "" }, actions: [ "find", "changeStream"] }

El rol read incorporado proporciona los privilegios apropiados.

MongoDB ofrece múltiples maneras de iterar sobre un cursor.

El cursor.hasNext() método se bloquea y espera el siguiente evento. Para supervisar el cursor watchCursor e iterar sobre los eventos, utiliza hasNext() de esta manera:

while (!watchCursor.isClosed()) {
if (watchCursor.hasNext()) {
firstChange = watchCursor.next();
break;
}
}

El cursor.tryNext() método es no bloqueante. Para supervisar el cursor watchCursor e iterar sobre los eventos, utiliza tryNext() de esta manera:

while (!watchCursor.isClosed()) {
let next = watchCursor.tryNext()
while (next !== null) {
printjson(next);
next = watchCursor.tryNext()
}
}

La siguiente operación en abre un cursor de mongosh flujo hr de cambios en la base de datos. El cursor devuelto informa sobre los cambios de datos en todas las colecciones que no seansystem de esa base de datos.

watchCursor = db.getSiblingDB("hr").watch()

Itera el cursor para verificar si hay nuevos eventos. Utiliza el método cursor.isClosed() junto con el método cursor.tryNext() para asegurarte de que el bucle solo salga si el cursor del flujo de cambios está cerrado y no quedan objetos en el último grupo:

while (!watchCursor.isClosed()) {
let next = watchCursor.tryNext()
while (next !== null) {
printjson(next);
next = watchCursor.tryNext()
}
}

Para obtener la documentación completa sobre la salida del flujo de cambios, consultar Eventos de cambios.

Nota

No puedes usar isExhausted() con flujos de cambios.

Volver

db.version

En esta página