Overview
En esta guía, puede aprender cómo configurar las opciones de preocupación de escritura, preocupación de lectura y preferencia de lectura para modificar la forma en que el controlador Java ejecuta operaciones de lectura y escritura en conjuntos de réplicas.
Prioridad de configuración de lectura y guardado
Puedes establecer las opciones de nivel de confirmación de escritura (write concern), nivel de consistencia de lectura y preferencia de lectura en los siguientes niveles:
Cliente, que establece el por defecto para todas las ejecuciones de operaciones, a menos que se anule
transacción
Database
Colección
Esta lista también indica el orden creciente de prioridad de las configuraciones de opciones. Por ejemplo, si se establece un nivel de consistencia de lectura para una transacción, se anularán las configuraciones de nivel de consistencia de lectura heredadas del cliente.
Las opciones de escritura, lectura y preferencia de lectura permiten personalizar la consistencia causal y la disponibilidad de los datos en los conjuntos de réplicas. Para ver una lista completa de estas opciones, consulte las siguientes guías en el manual de MongoDB Server:
Configurar operaciones de lectura y guardar
Se puede controlar cómo el driver enruta las operaciones de lectura entre los miembros del set de réplicas estableciendo una preferencia de lectura. También puedes controlar cómo el driver espera el reconocimiento de las operaciones de lectura y nivel de confirmación de escritura (write concern) en un set de réplicas configurando los concerns de lectura y nivel de confirmación de escritura (write concern).
Las siguientes secciones muestran cómo configurar estos parámetros de lectura y guardado en varios niveles.
Configuración del cliente
Este ejemplo muestra cómo establecer la preferencia de lectura, el nivel de consistencia de lectura y el nivel de confirmación de escritura (write concern) de un MongoClient instancia pasando una instancia MongoClientSettings al constructor. El código configura los siguientes ajustes:
secondarypreferencia de lectura: las operaciones de lectura recuperan datos de miembros secundarios del set de réplicas.LOCALPreocupación de lectura: las operaciones de lectura devuelven los datos más recientes de la instancia sin garantizar que los datos se hayan escrito en la mayoría de los miembros del conjunto de réplicas.W2nivel de confirmación de escritura (write concern): El primario del set de réplicas y un secundario deben reconocer la operación de grabación.
MongoClient mongoClient = MongoClients.create(MongoClientSettings.builder() .applyConnectionString(new ConnectionString("mongodb://localhost:27017/")) .readPreference(ReadPreference.secondary()) .readConcern(ReadConcern.LOCAL) .writeConcern(WriteConcern.W2) .build());
Alternativamente, se pueden especificar los ajustes de lectura y guardado en el URI de conexión, que se pasa como un parámetro al constructor MongoClients:
MongoClient uriClient = MongoClients.create("mongodb://localhost:27017/?readPreference=secondary&w=2&readConcernLevel=local");
Configuración de transacciones
Este ejemplo muestra cómo configurar la preferencia de lectura, la preocupación de lectura y la preocupación de escritura de una transacción pasando una TransactionOptions instancia al método.startTransaction() Las transacciones se ejecutan dentro de sesiones, que son agrupaciones de operaciones de lectura o escritura relacionadas que se ejecutan secuencialmente. Antes de aplicar las opciones de transacción, cree una ClientSession instancia para iniciar una sesión.
Tip
Para obtener más información sobre las sesiones, consulte Sesiones del Servidor en el manual del MongoDB Server.
El ejemplo configura los siguientes ajustes:
primarypreferencia de lectura: las operaciones de lectura recuperan datos del miembro del conjunto de réplicas principal.MAJORITYnivel de consistencia de lectura: Las operaciones de lectura devuelven los datos más recientes de la instancia que se han escrito en la mayoría de los miembros del set de réplicas.W1Preocupación de escritura: el miembro principal del conjunto de réplicas debe reconocer la operación de escritura.
TransactionOptions tOptions = TransactionOptions.builder() .readPreference(ReadPreference.primary()) .readConcern(ReadConcern.MAJORITY) .writeConcern(WriteConcern.W1) .build(); try (ClientSession clientSession = client.startSession()) { clientSession.startTransaction(tOptions); // Specify transaction operations here }
Configuración de la base de datos
Este ejemplo muestra cómo establecer la preferencia de lectura, la preocupación de lectura y la preocupación de escritura de una base de datos llamada test_database encadenando métodos setter al método getDatabase(). El código configura los siguientes ajustes:
primaryPreferredpreferencia de lectura: las operaciones de lectura recuperan datos del miembro del conjunto de réplicas principal o de miembros secundarios si el principal no está disponible.AVAILABLEPreocupación de lectura: las operaciones de lectura devuelven los datos más recientes de la instancia sin garantizar que los datos se hayan escrito en la mayoría de los miembros del conjunto de réplicas.MAJORITYnivel de confirmación de escritura (write concern): La mayoría de todos los miembros del set de réplicas deben reconocer la operación de escritura.
MongoDatabase database = mongoClient.getDatabase("test_database") .withReadPreference(ReadPreference.primaryPreferred()) .withReadConcern(ReadConcern.AVAILABLE) .withWriteConcern(WriteConcern.MAJORITY);
Configuración de la colección
Este ejemplo muestra cómo configurar la preferencia de lectura, el nivel de consistencia de lectura y el nivel de confirmación de escritura (write concern) de una colección llamada test_collection, encadenando métodos setters al método getCollection(). El código configura la siguiente configuración:
secondaryPreferredpreferencia de lectura: Las operaciones de lectura recuperan datos de los miembros secundarios del set de réplicas, o de los miembros primarios si no se dispone de miembros secundarios.AVAILABLEPreocupación de lectura: las operaciones de lectura devuelven los datos más recientes de la instancia sin garantizar que los datos se hayan escrito en la mayoría de los miembros del conjunto de réplicas.UNACKNOWLEDGEDnivel de confirmación de escritura (write concern): Los miembros del conjunto de réplicas no necesitan reconocer la operación de escritura.
MongoCollection<Document> collection = database.getCollection("test_collection") .withReadPreference(ReadPreference.secondaryPreferred()) .withReadConcern(ReadConcern.AVAILABLE) .withWriteConcern(WriteConcern.UNACKNOWLEDGED);
Configuraciones avanzadas de lectura
Las siguientes secciones describen formas de personalizar aún más cómo el controlador Java enruta las operaciones de lectura.
Clústeres fragmentados
Puede especificar una preferencia de lectura al conectarse a un clúster fragmentado. MongoDB utiliza la fragmentación para dividir los conjuntos de datos por rangos de claves y distribuir los datos entre varias instancias de base de datos. Un clúster fragmentado, o el conjunto de nodos en una implementación fragmentada, incluye los siguientes componentes:
Partición: Un set de réplicas que contiene un subconjunto de los datos particionados.
Mongos: un enrutador de consultas que proporciona una interfaz entre su aplicación y el clúster fragmentado.
Servidores de configuración: servidores que almacenan la configuración y los metadatos del clúster.
Tip
Para obtener más información sobre los clústeres compartimentados, consulte Particionado en el manual de MongoDB Server.
Al leer desde las particiones del set de réplicas, mongos aplica la preferencia de lectura especificada. La preferencia de lectura se vuelve a evaluar para cada operación.
El siguiente ejemplo muestra cómo conectarse a un clúster fragmentado y especificar una preferencia de lectura secondary en su cadena de conexión:
MongoClient uriClient = MongoClients.create("mongodb://user:password@mongos1.example.com,mongos2.example.com/?readPreference=secondary");
Conjuntos de etiquetas
En MongoDB Server, puede aplicar etiquetas clave-valor a los miembros del conjunto de réplicas según el criterio que elija. Después, puede usar esas etiquetas para seleccionar uno o más miembros para una operación de lectura.
De forma predeterminada, el controlador de Java ignora las etiquetas al elegir un miembro para leer. Para indicarle que prefiera ciertas etiquetas, páselas como una lista a su método de configuración de preferencias de lectura.
Supongamos que está conectado a un conjunto de réplicas que contiene miembros alojados en varios centros de datos en Estados Unidos. Quiere que el controlador prefiera las lecturas de los miembros del conjunto de réplicas secundario en el siguiente orden:
Miembros del centro de datos de Nueva York, etiquetados con
("dc", "ny")Nodos del centro de datos de San Francisco, etiquetados con
("dc", "sf")Cualquier miembro secundario
Este ejemplo de código pasa una lista de etiquetas que representan a los miembros anteriores del set de réplicas al método setter ReadPreference.secondary(). Luego, el código pasa la información de preferencia de lectura al método withReadPreference() para establecer el orden de lectura en la base de datos:
TagSet tag1 = new TagSet(new Tag("dc", "ny")); TagSet tag2 = new TagSet(new Tag("dc", "sf")); TagSet tag3 = new TagSet(); ReadPreference readPref= ReadPreference.secondary(Arrays.asList(tag1, tag2, tag3)); MongoDatabase database = mongoClient.getDatabase("test_database") .withReadPreference(readPref);
Equilibrio de carga
Al conectarse a un clúster o a un set de réplicas, el driver de Java utiliza el balanceo de carga para gestionar las solicitudes de lectura. El balanceo de carga permite que el controlador distribuya estas solicitudes entre varios servidores, lo que evita sobrecargar cualquier servidor y garantiza un rendimiento óptimo.
Al conectarse a un clúster fragmentado, el controlador Java determina la instancia mongos más cercana calculando cuál tiene el menor tiempo de ida y vuelta en la red. Luego, el controlador determina la ventana de latencia añadiendo el tiempo promedio de ida y vuelta de este mongos al valor localThresholdMS. El controlador equilibra la carga de las solicitudes entre hasta dos instancias de mongos seleccionadas al azar que se encuentran dentro de la ventana de latencia. Para cada solicitud, el driver elige el servidor con la carga de operación más baja determinando su valor de operationCount.
Al conectarse a un set de réplicas, el driver de Java primero selecciona los miembros del set de réplicas según la preferencia de lectura. Luego, el conductor sigue el mismo proceso que se describe en el párrafo anterior. Después de calcular la ventana de latencia, el driver selecciona hasta dos miembros del set de réplicas aleatorios dentro de la ventana y elige al nodo con el menor valor de operationCount para recibir la solicitud.
Tip
Para obtener más información sobre el balanceo de carga, consulte Balanceador de clúster en el manual de MongoDB Server.
Para aprender a personalizar el comportamiento de selección del servidor del controlador, consulte Configuraciones del clúster en la guía Especificar configuraciones de MongoClient.
Umbral local
El controlador de Java utiliza el valor umbral local para calcular la ventana de latencia para la selección de servidores. Este valor determina los servidores que son elegibles para recibir solicitudes de lectura y guardado.
Por defecto, el driver utiliza únicamente las instancias de mongos o los miembros del set de réplicas cuyo tiempo de ping esté dentro de 15 milisegundos del servidor más cercano. Para distribuir lecturas entre servidores con latencias más altas, configure la opción localThreshold en una instancia MongoClientSettings o la opción localThresholdMS en su URI de conexión.
Nota
Al seleccionar miembros del set de réplicas de una sola instancia de mongos, el driver de Java ignora la opción localThresholdMS. En este caso, use la opción de línea de comandos localThreshold.
El siguiente ejemplo se conecta a un set de réplicas y especifica un umbral local de 35 milisegundos. Elija el MongoClientSettings o la pestaña Connection URI para ver el código correspondiente para cada enfoque:
MongoClient client = MongoClients.create(MongoClientSettings.builder() .applyConnectionString(new ConnectionString("mongodb://localhost:27017/")) .applyToClusterSettings(builder -> builder.localThreshold(35, TimeUnit.MILLISECONDS)) .build());
String connectionString = "mongodb://localhost:27017/?replicaSet=repl0&localThresholdMS=35"; MongoClient client = MongoClients.create(connectionString);
En el ejemplo anterior, el controlador Java distribuye lecturas entre los miembros coincidentes dentro de 35 milisegundos del tiempo de ping del miembro más cercano.
Documentación de la API
Para aprender más sobre cualquiera de los métodos o tipos analizados en esta guía, consulta la siguiente documentación de API: