Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

Algoritmo de selección de servidor

Los drivers de MongoDB utilizan un algoritmo de selección de servidor para elegir qué miembro del set de réplicas usar o, cuando se conecta a múltiples mongos instancias, las cuales mongos instancia usar.

La selección del servidor se produce una vez por operación.

Nota

Las transacciones que contienen operaciones de lectura deben usar la preferencia de primary lectura. Todas las operaciones de una transacción deben dirigirse al mismo miembro.

La selección de servidor ocurre una vez por operación y está regida por la preferencia de lectura y la configuración de localThresholdMS para determinar la elegibilidad de los nodos para lecturas. La preferencia de lectura se reevalúa para cada operación.

Modo de preferencia de lectura
Proceso de Selección

primary (por defecto)

  1. El driver selecciona el primario.

  1. El controlador reúne una lista de miembros secundarios elegibles. LosmaxStalenessSeconds y los conjuntos de etiquetas especificados en la preferencia de lectura pueden restringir aún más la elegibilidad de los miembros.

  2. Si la lista de nodos elegibles no está vacía, el driver determina qué nodo elegible es el "más cercano" (es decir, el nodo con el menor promedio de tiempo de ida y vuelta de la red) y calcula una ventana de latencia sumando el promedio de tiempo de ida y vuelta de este servidor "más cercano" y el localThresholdMS. El driver utiliza esta ventana de latencia para reducir la lista de nodos elegibles a aquellos nodos que caen dentro de esta ventana.

  3. De esta lista de nodos aptos que se encuentran dentro de la ventana de latencia, el driver selecciona aleatoriamente un nodo apto.

  1. El controlador reúne una lista de miembros elegibles (principales y secundarios). maxStalenessSeconds y los conjuntos de etiquetas especificados en la preferencia de lectura pueden limitar aún más la elegibilidad de los miembros.

  2. Si la lista de nodos elegibles no está vacía, el driver determina cuál es el nodo "más cercano" (es decir, el nodo con el menor tiempo de ida y vuelta promedio de red) y calcula una ventana de latencia sumando el tiempo de ida y vuelta promedio de este servidor "más cercano" y el localThresholdMS [1]. El driver utiliza esta ventana de latencia para reducir la lista de nodos elegibles a aquellos nodos que se encuentren dentro de este rango.

  3. De esta lista de nodos aptos que se encuentran dentro de la ventana de latencia, el driver selecciona aleatoriamente un nodo apto.

  1. Si está disponible, el driver selecciona el primario.

  2. Si el primario no está disponible, la selección del servidor sigue el proceso de la preferencia de lectura secondary para seleccionar un secundario elegible.

  1. Después del proceso de selección del servidor para la preferencia de lectura secondary, si una lista de miembros secundarios elegibles no está vacía, el controlador elige un miembro secundario elegible.

  2. De lo contrario, si la lista está vacía, el controlador selecciona la principal.

Si hay más de una mongos instancia en la lista de nodos iniciales, el controlador determina cuál mongos es el "más cercano" (es decir, el miembro con el menor tiempo promedio de ida y vuelta en la red) y calcula la ventana de latencia sumando el tiempo promedio de ida y vuelta de esta mongos instancia "más cercana" y el localThresholdMS. El controlador equilibrará la carga aleatoriamente entre las instancias de mongos que se encuentren dentro de la ventana de latencia.

Para los clústeres fragmentados que tienen fragmentos de set de réplicas, mongos aplica la preferencia de lectura al leer de los fragmentos. La selección del servidor está gobernada por la preferencia de lectura y los ajustes de replication.localPingThresholdMs. La preferencia de lectura se vuelve a evaluar para cada operación.

Modo de preferencia de lectura
Proceso de Selección

primary (por defecto)

  1. El mongos selecciona el primario.

  1. El mongos crea una lista de miembros secundarios elegibles. maxStalenessSeconds y conjuntos de etiquetas especificados en la preferencia de lectura pueden restringir aún más la elegibilidad de los nodos.

  2. Si la lista de miembros elegibles no está vacía,mongos determina cuál es el miembro elegible más cercano (es decir, el miembro con el menor tiempo promedio de ida y vuelta en la red) y calcula una ventana de latencia sumando el tiempo promedio de ida y vuelta de este servidor más cercano y replication.localPingThresholdMs (o --localThreshold la opción de línea de comandos). utiliza esta ventana de latencia para reducir la lista de miembros elegibles a aquellos que se encuentran dentro de mongos ella.

  3. De esta lista de nodos elegibles que se encuentran dentro de la ventana de latencia, el mongos elige aleatoriamente un nodo elegible.

  1. El mongos ensambla una lista de nodos elegibles (primarios y secundarios). maxStalenessSeconds y conjuntos de etiquetas especificados en la preferencia de lectura pueden limitar aún más la elegibilidad de los nodos.

  2. Si la lista de miembros elegibles no está vacía, el mongos determina qué miembro elegible está "más cerca" (es decir, el miembro con el menor promedio de tiempo de ida y vuelta en la red) y calcula una ventana de latencia sumando el tiempo promedio de ida y vuelta de este servidor "más cercano" y el replication.localPingThresholdMs (o la --localThreshold opción de la línea de comandos) [1]. El mongos usa esta ventana de latencia para reducir la lista de miembros elegibles a aquellos que están dentro de esta ventana.

  3. De esta lista de nodos elegibles que se encuentran dentro de la ventana de latencia, el mongos elige aleatoriamente un nodo elegible.

  1. Si el primario está disponible, mongos selecciona el primario.

  2. Si el primario no está disponible, la selección del servidor sigue el proceso de preferencia de lectura secondary.

  1. Tras el proceso de selección del servidor para la preferencia de lectura secondary, si la lista de miembros secundarios elegibles no está vacía, mongos elige un secundario eligible.

  2. Si la lista de miembros secundarios elegibles está vacía, mongos selecciona el principal.

[1](1, 2) El valor umbral por defecto es de 15 milisegundos.

Volver

Lecturas protegidas

En esta página