Docs Menu
Docs Home
/ /
Cursors

cursor.noCursorTimeout() (método mongosh)

cursor.noCursorTimeout()

Importante

Método mongosh

Esta página documenta un método mongosh. Esta no es la documentación para un driver específico de lenguaje, como Node.js.

Para los drivers de API de MongoDB, consulte la documentación del driver de MongoDB específica del lenguaje.

Instruye al servidor para que evite cerrar automáticamente un cursor después de un período de inactividad.

El método tiene la siguiente forma de noCursorTimeout() prototipo:

db.collection.find(<query>).noCursorTimeout()

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

Importante

Este comando no es compatible con los clústeres M0 y Flex. Para obtener más información, consulta 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.

Los drivers de MongoDB y mongosh asocian todas las operaciones con una sesión de servidor, con la excepción de las operaciones de escritura no reconocidas. Para las operaciones no asociadas explícitamente a una sesión (es decir, mediante Mongo.startSession()), los drivers de MongoDB y mongosh crean una sesión implícita y la asocian con la operación.

Si una sesión permanece inactiva durante más de 30 minutos, el servidor MongoDB la marca como expirada y puede cerrarla en cualquier momento. Al cerrar la sesión, también elimina cualquier operación en curso y los cursores abiertos asociados a ella. Esto incluye los cursores configurados con noCursorTimeout() o un superior maxTimeMS() a 30 minutos.

Considere una aplicación que emite undb.collection.find()concursor.noCursorTimeout(). El servidor devuelve un cursor junto con un lote de documentos definido por elcursor.batchSize()defind(). La sesión se actualiza cada vez que la aplicación solicita un nuevo lote de documentos al servidor. Sin embargo, si la aplicación tarda más de 30 minutos en procesar el lote actual de documentos, la sesión se marca como expirada y se cierra. Al cerrar la sesión, el servidor también elimina el cursor, a pesar de que esté configurado connoCursorTimeout(). Al solicitar el siguiente lote de documentos, el servidor devuelve un error.

Para las operaciones que devuelven un cursor, si el cursor puede estar inactivo durante más de 30 minutos, emite la operación dentro de una sesión explícita utilizando Mongo.startSession() y actualiza periódicamente la sesión utilizando el comando refreshSessions. Por ejemplo:

var session = db.getMongo().startSession()
var sessionId = session
sessionId // show the sessionId
var cursor = session.getDatabase("examples").getCollection("data").find().noCursorTimeout()
var refreshTimestamp = new Date() // take note of time at operation start
while (cursor.hasNext()) {
// Check if more than 5 minutes have passed since the last refresh
if ( (new Date()-refreshTimestamp)/1000 > 300 ) {
print("refreshing session")
db.adminCommand({"refreshSessions" : [sessionId]})
refreshTimestamp = new Date()
}
// process cursor normally
}

En la operación de ejemplo, el métododb.collection.find()está asociado a una sesión explícita. El cursor se configura concursor.noCursorTimeout()para evitar que el servidor lo cierre si está inactivo. El bucle while incluye un bloque que usarefreshSessionspara actualizar la sesión cada 5 minutos. Dado que la sesión nunca superará el tiempo de inactividad de 30 minutos, el cursor puede permanecer abierto indefinidamente.

Para los controladores de MongoDB, consulta la documentación del controlador para obtener instrucciones y la sintaxis para crear sesiones.

Volver

cursor.siguiente

En esta página