Definición
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 sus
systemcolecciones que no sean.ParameterTipoDescripciónpipelinearreglo
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.
optionsDocumento
Opcional. Opciones adicionales que modifican el comportamiento de
db.watch().El documento
optionspuede contener los siguientes campos y valores:CampoTipoDescripciónresumeAfterDocumento
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
invalidateevento.resumeAfteres mutuamente excluyente constartAfterystartAtOperationTime.startAfterDocumento
Opcional. Especifica un token de reanudación como el punto de inicio lógico para el flujo de cambios. A diferencia de
resumeAfter,startAfterpuede reanudar las notificaciones después de un eventoinvalidatecreando un nuevo flujo de cambios.startAfteres mutuamente excluyente conresumeAfterystartAtOperationTime.fullDocumentstring
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
fullDocumenten"updateLookup"para dirigir adb.watch()a buscar la versión más reciente del documento actualizado que haya sido comprometida por la mayoría.db.watch()devuelve un campofullDocumentcon la búsqueda de documentos además del delta deupdateDescription.A partir de MongoDB 6.0, puede configurar
fullDocumentpara:"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.
fullDocumentBeforeChangestring
Opcional. El valor por defecto es
"off".A partir de MongoDB 6.0, puede usar el nuevo campo
fullDocumentBeforeChangey 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.
batchSizeInt
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().maxAwaitTimeMSInt
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
1000milisegundos.collationDocumento
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.startAtOperationTimeMarca 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().startAtOperationTimees mutuamente excluyente conresumeAfterystartAfter.Devuelve: Un cursor sobre los documentos de eventos de cambio. Consulte Eventos de cambio para ver ejemplos de documentos de eventos de cambio.
Compatibilidad
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.
Disponibilidad
Implementación
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 instanciamongos.
Motor de almacenamiento
Solo se puede usar db.watch() con el motor de almacenamiento WiredTiger.
Leer Preocupación majority Soporte
Los flujos de cambios están disponibles independientemente del soporte de "majority" de nivel de consistencia de lectura; es decir, el soporte de nivel de consistencia de lectura majority puede estar habilitado (por defecto) o deshabilitado para usar flujos de cambios.
Comportamiento
No puede ejecutar en
db.watch()laadminlocalconfigbase 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 particionado, la eliminación de una partición puede provocar que un cursor del flujo de cambios abierto se cierre. Es posible que el cursor cerrado del flujo de cambios no sea completamente reanudable.
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.
Reanudabilidad
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
resumeAfterpara 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 particionado, la eliminación de una partición puede provocar que un cursor del flujo de cambios abierto se cierre. Es posible que el cursor cerrado del flujo de cambios no sea completamente reanudable.
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.
Consulta completa de documentos de operaciones de actualizació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.
Control de acceso
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.
Iteración de cursor
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() } }
Ejemplo
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.