Nota
O acceso a esta páxina require autorización. Pode tentar iniciar sesión ou modificar os directorios.
O acceso a esta páxina require autorización. Pode tentar modificar os directorios.
Se aplica a:SQL Server
En Grupos de disponibilidad AlwaysOn, el modo de disponibilidad es una propiedad de réplica que determina si una réplica de disponibilidad determinada puede ejecutarse en modo de confirmación sincrónica. En cada réplica de disponibilidad se debe configurar el modo de disponibilidad para el modo de confirmación sincrónica, el modo de confirmación asincrónica o el modo de solo configuración.
Si la réplica principal está configurada para el modo de confirmación asincrónica, no espera a que ninguna réplica secundaria escriba registros de registro de transacciones entrantes en el disco (para proteger el registro).
Si una réplica secundaria está configurada para el modo de confirmación asincrónica, la réplica principal no espera a que esa réplica secundaria durabilice el registro. Si la réplica principal y una réplica secundaria determinada se configuran ambas para el modo de confirmación sincrónica, la réplica principal espera a que la réplica secundaria confirme que ha reforzado el registro (a menos que la réplica secundaria no pueda hacer ping a la réplica principal en el período de tiempo de espera de sesiónde la principal).
Nota:
Si una réplica secundaria de confirmación sincrónica supera el período de tiempo de espera de sesión de la réplica principal (el valor predeterminado es de 10 segundos), la réplica principal marca temporalmente el estado de sincronización de cada base de datos de esta réplica secundaria como NOT SYNCHRONIZING y el estado de la réplica como NOT_HEALTHY. Cuando la replicación secundaria vuelva a conectarse con la replicación primaria, se reanuda el modo de confirmación sincrónica.
Modos de disponibilidad admitidos
Los grupos de disponibilidad AlwaysOn admiten tres modos de disponibilidad:
- Modo de confirmación asincrónica
- Modo de confirmación sincrónica
- Modo de solo configuración
Modo de confirmación asincrónica es una solución de recuperación ante desastres que funciona bien cuando las réplicas de disponibilidad se distribuyen a distancias considerables. Si cada réplica secundaria se ejecuta en modo de confirmación asincrónica, la réplica principal no espera a que ninguna de las réplicas secundarias confirme el registro. En su lugar, inmediatamente después de escribir el registro en el archivo de registro local, la réplica principal envía la confirmación de la transacción al cliente. La réplica principal se ejecuta con la mínima latencia de transacciones respecto a una réplica secundaria que se configura para el modo de confirmación asincrónica.
Si la principal actual está configurada para el modo de disponibilidad de confirmación asincrónica, confirma las transacciones de forma asincrónica para todas las réplicas secundarias, independientemente de su configuración de modo de disponibilidad individual.
Para obtener más información, consulte Modo de disponibilidad Asynchronous-Commit, más adelante en este artículo.
Elmodo de confirmación sincrónica establece prioridades de alta disponibilidad sobre el rendimiento, pero a costa de aumentar la latencia de las transacciones. En modo de confirmación sincrónica, las transacciones esperan a enviar la confirmación de transacción al cliente hasta que la réplica secundaria ha protegido el registro en el disco. Cuando la sincronización de datos comienza en una base de datos secundaria, la réplica secundaria comienza a aplicar los registros entrantes desde la base de datos principal correspondiente. En cuanto se ha confirmado cada registro de eventos, la base de datos secundaria entra en el estado SYNCHRONIZED. Después, la réplica secundaria protege cada nueva transacción antes de que se escriba la entrada de registro en el archivo de registro local. Cuando todas las bases de datos secundarias de una réplica secundaria se sincronizan, el modo de confirmación sincrónica admite la conmutación por error manual y, opcionalmente, la conmutación automática por error.
Más adelante en este artículo, consulte modo de disponibilidad de Synchronous-Commit para obtener más información.
Modo solo de configuración se aplica a los grupos de disponibilidad que no están en un clúster de conmutación por error de Windows Server. Una réplica en modo de solo configuración no contiene datos de usuario. En el modo solo de configuración, la base de datos de réplica master almacena los metadatos de configuración del grupo de disponibilidad. Para más información, vea Alta disponibilidad y protección de datos para las configuraciones de grupo de disponibilidad.
En la ilustración siguiente se muestra un grupo de disponibilidad con cinco réplicas de disponibilidad. La réplica principal y una réplica secundaria se configuran para el modo de confirmación sincrónica con conmutación automática por error. Se configura otra réplica secundaria para el modo de confirmación sincrónica con conmutación por error manual planeada únicamente y se configuran dos réplicas secundarias para el modo de confirmación asincrónica, que solo admite la conmutación por error manual forzada (denominada normalmente conmutación por error forzada).
El comportamiento de sincronización y conmutación por error entre dos réplicas de disponibilidad depende del modo de disponibilidad de ambas réplicas. Por ejemplo, para que se produzca una confirmación sincrónica, tanto la réplica principal como la réplica secundaria deben configurarse para la confirmación sincrónica. Del mismo modo, para el failover automático, ambas réplicas deben configurarse para este proceso de forma automática. Por lo tanto, el comportamiento del escenario de implementación ilustrado anteriormente se puede resumir en la tabla siguiente, que explora el comportamiento con cada posible réplica principal:
| Réplica principal actual | Destinos de conmutación por error automática | Comportamiento del modo de confirmación sincrónica con | Comportamiento del modo de confirmación asincrónica con | Conmutación por error automática posible |
|---|---|---|---|---|
| 01 | 02 | 02 y 03 | 04 | Sí |
| 02 | 01 | 01 y 03 | 04 | Sí |
| 03 | 01 y 02 | 04 | No | |
| 04 | 01, 02 y 03 | No |
Normalmente, el nodo 04 como réplica de confirmación asincrónica, se implementa en un sitio de recuperación ante desastres. El hecho de que los nodos 01, 02, 03 se mantengan en el modo de confirmación asincrónica después de conmutar por error al nodo 04 ayuda a evitar la degradación del rendimiento potencial en el grupo de disponibilidad debido a la alta latencia de red entre los dos sitios.
Modo asincrónico de disponibilidad de confirmación
En el modo de confirmación asincrónica, la réplica secundaria nunca se sincroniza con la réplica principal. Aunque una base de datos secundaria puede tener acceso a la base de datos principal correspondiente, cualquier base de datos secundaria podría retrasarse en cualquier momento. El modo de confirmación asincrónica puede ser útil en un escenario de recuperación ante desastres en el que la réplica principal y la réplica secundaria están separadas por una distancia significativa y donde no desea que los errores pequeños afecten a la réplica principal o en situaciones en las que el rendimiento sea más importante que la protección de datos sincronizada. Además, dado que la réplica principal no espera confirmaciones de la réplica secundaria, los problemas de la réplica secundaria nunca afectan a la réplica principal.
Una réplica secundaria de confirmación asincrónica intenta hacer frente a las entradas de registro recibidas de la réplica principal. Pero en modo de confirmación asincrónica, las bases de datos secundarias permanecen sin sincronizar y es más probable que se retrasen detrás las bases de datos principales. Normalmente, la diferencia entre una base de datos secundaria de confirmación asincrónica y la base de datos principal correspondiente es pequeña. Pero la diferencia puede ser considerable si el servidor que hospeda la replicación secundaria está sobrecargado o la red es lenta.
El único formato de conmutación por error que admite el modo de confirmación asincrónica es conmutación por error forzada (con posible pérdida de datos). Forzar la conmutación es un último recurso destinado únicamente para situaciones en las que la réplica principal actual permanece disponible durante un período prolongado y la disponibilidad inmediata de las bases de datos principales es más importante que el riesgo de posibles pérdidas de datos. El destino de conmutación por error debe ser una réplica cuyo estado del rol esté en SECONDARY o RESOLVING. El destino de la conmutación por error asume el rol principal y sus copias de las bases de datos se convierten en la base de datos principal. Cualquier base de datos secundaria restante, junto con las bases de datos principales anteriores, una vez que estén disponibles, se suspende hasta que se reanuden de forma manual e individualmente. En el modo de confirmación asincrónica, se pierden los registros de transacciones que la réplica principal original aún no había enviado a la réplica secundaria anterior. Esto significa que algunas o todas las nuevas bases de datos principales podrían carecer de las transacciones confirmadas recientemente. Para más información sobre el funcionamiento de la conmutación por error forzada y los procedimientos recomendados para usarla, consulte Conmutación por error y modos de conmutación por error (grupos de disponibilidad AlwaysOn).
Modo de disponibilidad de confirmación sincrónica
En el modo de disponibilidad de confirmación sincrónica, después de unirse a un grupo de disponibilidad, una base de datos secundaria alcanza a la base de datos principal correspondiente y entra en el estado de SYNCHRONIZED. La base de datos secundaria permanece SYNCHRONIZED siempre que continúe la sincronización de datos. Esto garantiza que todas las transacciones confirmadas en una base de datos principal determinada se confirmen en la base de datos secundaria correspondiente. Cuando se sincronizan todas las bases de datos secundarias de una réplica secundaria determinada, el estado de mantenimiento de sincronización de la réplica secundaria en su conjunto es HEALTHY.
Esta sección:
- Factores que interrumpen la sincronización de datos
- Funcionamiento de la sincronización en una réplica secundaria
- Modo de confirmación sincrónica con solo conmutación por error manual
- Modo de confirmación sincrónica con conmutación automática por error
Factores que interrumpen la sincronización de datos
Una vez sincronizadas todas sus bases de datos, una réplica secundaria entra en el HEALTHY estado . La réplica secundaria sincronizada permanece en buen estado a menos que se produzca una de las siguientes acciones:
Un retraso de la red, del equipo o una interferencia provoca que se agote el tiempo de espera de la sesión entre la réplica secundaria y la réplica principal.
Nota:
Para obtener información sobre la propiedad en tiempo de sesión de las réplicas de disponibilidad, consulte ¿Qué es un grupo de disponibilidad AlwaysOn?
Se suspende una base de datos secundaria en la réplica secundaria. La réplica secundaria deja de estar sincronizada y su estado de sincronización se marca como NOT_HEALTHY. La réplica secundaria no puede volver a estar en buen estado hasta que la base de datos secundaria suspendida se reanude y se vuelva a sincronizar o se quite del grupo de disponibilidad.
Agrega una base de datos principal al grupo de disponibilidad. Las réplicas secundarias sincronizadas previamente entran en el
NOT_HEALTHYestado de estado de sincronización. Este estado indica que al menos una base de datos está en estado deNOT SYNCHRONIZINGsincronización. Una réplica secundaria determinada no puede volver a estarHEALTHYhasta que se haya preparado una base de datos secundaria correspondiente en la réplica, se haya unido al grupo de disponibilidad y se sincronice con la nueva base de datos principal.Cambia la réplica principal o la réplica secundaria al modo de disponibilidad de confirmación asincrónica. Después de cambiar al modo de confirmación asincrónica, la réplica secundaria permanecerá en estado
HEALTHYde estado de sincronización mientras continúe la sincronización de datos. Sin embargo, si solo se cambia la réplica principal al modo de confirmación asincrónica, la réplica secundaria de confirmación sincrónica entrará en elPARTIALLY_HEALTHYestado de salud de sincronización. Este estado indica que al menos una base de datos está en estadoSYNCHRONIZINGde sincronización, pero ninguna de las bases de datos está en estadoNOT SYNCHRONIZING.Cambia cualquier réplica secundaria al modo de disponibilidad de confirmación sincrónica. Esto provoca que la réplica secundaria se marque como en el estado de salud de sincronización
PARTIALLY_HEALTHYhasta que todas sus bases de datos estén en el estado de sincronizaciónSYNCHRONIZED.
Sugerencia
Para ver el estado de sincronización de un grupo de disponibilidad, una réplica de disponibilidad o una base de datos de disponibilidad, consulte la synchronization_health columna o synchronization_health_desc de sys.dm_hadr_availability_group_states, sys.dm_hadr_availability_replica_states o sys.dm_hadr_database_replica_states, respectivamente.
Funcionamiento de la sincronización en una réplica secundaria
En modo de confirmación sincrónica, después de que una réplica secundaria se una al grupo de disponibilidad y establezca una sesión con la réplica principal:
- La réplica secundaria escribe registros de transacciones entrantes en el disco (hace persistente el registro).
- La réplica secundaria envía un mensaje de confirmación a la réplica principal.
Después de que el registro firmado de la base de datos secundaria se haya sincronizado con el final del registro en la base de datos principal, el estado de la base de datos secundaria se establece en SYNCHRONIZED.
El tiempo necesario para la sincronización depende de la distancia en que se encontraba la base de datos secundaria detrás de la base de datos principal al inicio de la sesión. Esta diferencia se mide por el número de registros de registro recibidos inicialmente de la réplica principal, la carga que soporta la base de datos principal y la velocidad del anfitrión de la instancia de la réplica secundaria.
El proceso de transacción
En modo de confirmación sincrónica, las transacciones se confirman en ambas réplicas en este orden:
La réplica principal recibe una transacción de un cliente.
La réplica principal escribe el registro en el registro de transacciones y envía simultáneamente el registro a las réplicas secundarias.
Una vez que se escribe un registro de registro en el registro de transacciones de la base de datos principal, la transacción solo se puede deshacer si hay una conmutación por error a una secundaria que no recibió el registro.
La réplica principal espera la confirmación de la réplica secundaria de confirmación sincrónica.
La réplica secundaria protege el registro y devuelve una confirmación a la réplica principal.
La réplica principal finaliza el procesamiento de confirmación y envía un mensaje de confirmación al cliente.
Tiempo de espera de confirmación sincrónica
Si una réplica secundaria de confirmación sincrónica agota el tiempo de espera sin confirmar que ha protegido el registro, se producen las siguientes acciones en el grupo de disponibilidad:
- La réplica principal marca esa réplica secundaria como fallida.
- El estado de la réplica secundaria cambia a
DISCONNECTED. - El primario deja de esperar la confirmación.
- El grupo de disponibilidad marca el estado de sincronización como
NOT SYNCHRONIZINGy el estado de réplica comoNOT_HEALTHY.
Este comportamiento garantiza que una réplica secundaria de confirmación sincrónica fallida no impida el endurecimiento del registro en la réplica principal.
Cuando la réplica secundaria vuelva a estar en línea:
- El estado de la réplica secundaria cambia a
CONNECTED. - La réplica secundaria procesa la cola de envío de registros de la réplica principal.
- El estado de sincronización pasa a
SYNCHRONIZINGy el estado de la réplica aPARTIALLY_HEALTHY.
Una vez procesada la cola de envío de registros, el estado de sincronización se convierte en SYNCHRONIZEDy el estado de la réplica se convierte en HEALTHY.
El modo de confirmación sincrónica protege los datos exigiendo que estos estén sincronizados entre dos lugares, a costa de un ligero aumento de la latencia de las transacciones.
Modo de confirmación sincrónica solo con conmutación por error manual
Cuando estas réplicas están conectadas y la base de datos está sincronizada, se admite la conmutación por error manual. Si la réplica secundaria baja un nivel, la réplica principal no se ve afectada. La réplica principal se ejecuta expuesta si no existe ninguna SYNCHRONIZED réplica (es decir, sin enviar datos a ninguna réplica secundaria). Si se pierde la réplica principal, las réplicas secundarias entran en el estado RESOLVING, pero el propietario de la base de datos puede forzar una conmutación por error a la réplica secundaria (con posible pérdida de datos). Para más información, consulte Conmutación por error y modos de conmutación por error (grupos de disponibilidad AlwaysOn).
Modo de confirmación sincrónica con conmutación automática ante fallos
La conmutación automática por error proporciona alta disponibilidad al asegurar que la base de datos estará de nuevo disponible rápidamente después de la pérdida de la réplica principal. Para configurar un grupo de disponibilidad para la conmutación automática por error, debe establecer la réplica principal actual y al menos una réplica secundaria en el modo de confirmación sincrónica con conmutación automática por error. SQL Server 2019 (15.x) aumentó el número máximo de réplicas sincrónicas a 5, de las 3 que eran en SQL Server 2017 (14.x). Puede configurar este grupo de cinco réplicas para habilitar la conmutación automática por error dentro del grupo. Hay una réplica principal, además de cuatro réplicas secundarias sincrónicas.
Además, para que la conmutación automática por error sea posible en un momento dado, esta réplica secundaria se debe sincronizar con la réplica principal (es decir, todas las bases de datos secundarias están sincronizadas), y los clústeres de conmutación por error de Windows Server (WSFC) deben tener quórum. Si la réplica principal no está disponible en estas condiciones, se produce la conmutación automática por error. La réplica secundaria cambia al rol de principal y ofrece su base de datos como la base de datos principal. Para obtener más información, consulte la sección "Conmutación automática por error" del artículo "Conmutación por error y Modos de conmutación por error (grupos de disponibilidad Always On)."
Nota:
Para más información sobre el cuórum WSFC y los grupos de disponibilidad AlwaysOn, consulte Configuración de los votos y modos de cuórum WSFC (SQL Server).
Latencia de datos en la réplica secundaria
La implementación del acceso de solo lectura en las réplicas secundarias resulta útil si las cargas de trabajo de solo lectura pueden tolerar cierta latencia de datos. En las situaciones en las que la latencia de datos no es aceptable, considere la posibilidad de ejecutar cargas de trabajo de solo lectura en la réplica principal.
La réplica principal envía las entradas de registro de los cambios en la base de datos principal a las réplicas secundarias. En cada base de datos secundaria, un subproceso de rehacer dedicado aplica las entradas de registro. En una base de datos secundaria de acceso de lectura, un cambio de datos determinado no aparece en los resultados de la consulta hasta que el registro de registro que contiene el cambio se ha aplicado a la base de datos secundaria y la transacción se ha confirmado en la base de datos principal.
Esto significa que hay cierta latencia, normalmente solo una cuestión de segundos, entre las réplicas principal y secundaria. No obstante, en casos excepcionales, por ejemplo, si los problemas de red reducen el rendimiento, la latencia puede ser importante. La latencia aumenta cuando se producen cuellos de botella de E/S y cuando se suspende el movimiento de los datos. Para supervisar el movimiento de datos suspendido, puede usar el panel del grupo de disponibilidad Always On (SQL Server Management Studio) o la vista de administración dinámica sys.dm_hadr_database_replica_states.
Para reducir la latencia en SQL Server 2025 (17.x) y versiones posteriores, puede reducir el tiempo (en milisegundos) que tarda la réplica principal en confirmar transacciones en la réplica secundaria. Para obtener más información, consulte Configuración del servidor: tiempo de confirmación del grupo de disponibilidad (ms).
Para cambiar el modo de disponibilidad y el modo de conmutación por error
- Cambio del modo de disponibilidad de una réplica dentro de un grupo de disponibilidad AlwaysOn
- Cambiar el modo de conmutación por error de una réplica dentro de un grupo de disponibilidad Always On
Para ajustar los votos de quórum
- Ver la configuración de NodeWeight de cuórum de clúster
- Configurar los valores de NodeWeight de cuórum de clúster
- Forzar el inicio de un clúster WSFC sin un quórum
Para realizar una conmutación manual por error
- Realizar una conmutación por error manual planeada de un grupo de disponibilidad AlwaysOn (SQL Server)
- Realización de una conmutación por error manual forzada de un grupo de disponibilidad Always On (SQL Server)
- Usar el Asistente para grupo de disponibilidad de conmutación por error (SQL Server Management Studio)
Para ver los estados del grupo de disponibilidad, la réplica de disponibilidad y las bases de datos
- sys.dm_hadr_availability_group_states
- sys.dm_hadr_availability_replica_states
- sys.dm_hadr_database_replica_states
Contenido relacionado
- Guía de soluciones AlwaysOn de Microsoft SQL Server para lograr alta disponibilidad y recuperación ante desastres
- Blog del equipo Always On de SQL Server: el blog oficial del equipo de Always On de SQL Server
- ¿Qué es un grupo de disponibilidad Always On?
- Conmutación por error y modos de conmutación por error (grupos de disponibilidad AlwaysOn)
- Clústeres de conmutación por error de Windows Server con SQL Server