Una consulta con nivel de consistencia de lectura "available" devuelve datos de la instancia sin garantías de que los datos se hayan escrito en la mayoría de los miembros del set de réplicas (es decir, es posible que se reviertan).
Para un clúster fragmentado, la lectura proporciona una mayor tolerancia a las
"available"particiones.Las
"available"con el nivel de consistencia de lectura no requieren una verificación para garantizar que la partición correcta haya recibido la query.En caso de particiones de red, estas consultas se dirigen al fragmento considerado apropiado antes de que se produjera la partición. No esperan garantías de consistencia de servidores que podrían no estar disponibles. Si el fragmento estaba en proceso de migración de fragmentos, las consultas con pueden
"available"devolver documento huérfano.Advertencia
mongosno garantiza que las consultas con nivel de consistencia de lectura"available"se dirijan a los shards correctos. La partición que recibe la query devuelve datos, pero es posible que esta partición no sea el propietario autorizado de los datos solicitados.Esto puede causar que las consultas devuelvan resultados incorrectos o inesperados.
Para las colecciones no particionadas (incluidas las colecciones en una implementación autónoma o una implementación de conjunto de réplicas),
"local"y"available"los niveles de consistencia de lectura se comportan de manera idéntica.
Independientemente del nivel de consistencia de lectura, es posible que los datos más recientes de un nodo no reflejen la versión más reciente de los datos en el sistema.
Disponibilidad
La preocupación leída "available" es No disponible para su uso con sesiones y transacciones causalmente coherentes.
Ejemplo
Considera la siguiente cronología de una operación de escritura. Escribe 0 en un set de réplicas de tres nodos:
Nota
Para simplificar, el ejemplo supone:
Todas las escrituras anteriores a Escritura 0 se han replicado exitosamente en todos los miembros.
Write prev es la guardar anterior a Write 0.
No se produjeron otras escrituras después de Escritura 0.
Tiempo | Evento | Último guardar | Más reciente w: "mayoría" guardar |
|---|---|---|---|
t 0 | El primario aplica guardar 0 | Primary: Write 0 Secondary 1: Write prev Secondary 2: Write prev | Primary: Write prev Secondary 1: Write prev Secondary 2: Write prev |
t 1 | Secundario 1 aplica guardar 0 | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write prev | Primary: Write prev Secondary 1: Write prev Secondary 2: Write prev |
t2 | Secundaria 2 aplica guardar 0 | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write 0 | Primary: Write prev Secondary 1: Write prev Secondary 2: Write prev |
t 3 | El primario está al tanto de la replicación exitosa al secundario 1 y envía un acuse de recibo al cliente. | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write 0 | Primary: Write 0 Secondary 1: Write prev Secondary 2: Write prev |
t 4 | El primario está al tanto de la replicación exitosa al secundario 2 | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write 0 | Primary: Write 0 Secondary 1: Write prev Secondary 2: Write prev |
t 5 | El Secundario 1 recibe la notificación (a través del mecanismo regular de replicación) para actualizar su snapshot de su última w: guardar de "mayoría" | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write 0 | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write prev |
t 6 | El secundario 2 recibe un aviso (a través del mecanismo de replicación regular) para actualizar su instantánea de su escritura w: "mayoría" más reciente | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write 0 | Primary: Write 0 Secondary 1: Write 0 Secondary 2: Write 0 |
Luego, la siguiente tabla resume el estado de los datos que una operación de lectura con "available" nivel de consistencia de lectura vería en el momento T.
Leer objetivo | Tiempo T | Estado de los datos |
|---|---|---|
Primario | Después de t 0 | Los datos reflejan Escritura 0. |
Secundaria 1 | Antes de t 1 | Los datos reflejan la escritura anterior |
Secundaria 1 | Después de t 1 | Los datos reflejan guardar 0 |
Secundario 2 | Antes de t 2 | Los datos reflejan la escritura anterior |
Secundario 2 | Después de t 2 | Los datos reflejan guardar 0 |