Acerca de los grupos de lectura

Los grupos de lectura de Cloud SQL admiten el balanceo de cargas para tus grandes cargas de trabajo de lectura.

¿Qué son los grupos de lectura?

Un grupo de lectura es una colección de instancias de réplica de lectura que se usa para distribuir tus grandes cargas de trabajo de lectura. Estas cargas de trabajo se pueden redireccionar desde la instancia principal al grupo de lectura para reducir la carga en la instancia principal.

Cada réplica de lectura del grupo de lectura se denomina nodo de grupo de lectura.

Puedes escalar tu grupo de lectura de varias maneras:

  • Aumentar o reducir la escala: Aumenta o reduce la capacidad de balanceo de cargas de forma horizontal modificando la cantidad de nodos del grupo de lectura. Cada grupo de lectura admite entre 1 y 7 nodos de grupo de lectura.
  • Aumentar o reducir la escala: Aumenta o reduce la capacidad del balanceo de cargas de forma vertical modificando el tipo de máquina asociado a un nodo del grupo de lectura. Una vez definida, la configuración se aplica de manera uniforme en cada nodo del grupo de lectura.

Cuando modificas la configuración de los nodos del grupo de lectura, como el almacenamiento, la conectividad o las marcas de configuración de la base de datos, los cambios se aplican automáticamente de manera uniforme en cada nodo del grupo de lectura.

Acceder a un grupo de lectura a través de un solo extremo de lectura

Se puede acceder al grupo de lectura a través de un solo extremo de lectura con una dirección IP inmutable. Las conexiones que se realizan a través del extremo se redireccionan automáticamente a uno de los nodos del grupo de lectura. Cuando quieres que el grupo de lectura se ajuste o se expanda, las aplicaciones que antes estaban conectadas a este único extremo de lectura no necesitan volver a configurarse, aunque puedes crear nodos nuevos en el grupo de lectura o borrar los anteriores.

Cada nodo del grupo de lectura también tiene su propia dirección IP. Si bien no se recomienda como un enfoque eficiente para acceder a tus datos, puedes usar estas direcciones IP para solucionar problemas de rendimiento de nodos individuales del grupo de lectura.

Para obtener más información sobre cómo recuperar la información de conexión del grupo de lectura o los nodos del grupo de lectura (direcciones IP o una cadena de conexión), consulta Cómo ver la información del grupo de lectura.

Replicación

La replicación del grupo de lectura de Cloud SQL se implementa con grupos de disponibilidad de escalamiento de lectura de SQL Server.

Para obtener más información, consulta Acerca de la replicación.

Características del grupo de lectura

Se aplican las siguientes características:

  • Un grupo de lectura con dos o más nodos está cubierto por el Acuerdo de Nivel de Servicio (ANS).
  • Los nodos del grupo de lectura siempre residen en la misma región, según lo especifica el usuario. Google Cloud alternates read pool node residency among all zones in the region.
  • Una instancia principal puede tener uno o más grupos de lectura.
  • Las siguientes operaciones generan un tiempo de inactividad inferior a un segundo:
    • Aumentar o reducir la escala (agregar o quitar nodos del grupo de lectura)
    • Aumentar o reducir la escala verticalmente (cambiar el tipo de máquina de los nodos del grupo)
    • Convertir una réplica de lectura zonal existente en un grupo de lectura
  • Un grupo de lectura recibe mantenimiento antes que su instancia principal, de manera similar a las réplicas de lectura. Al igual que las réplicas de lectura, los grupos de lectura reciben mantenimiento durante el período de mantenimiento de la instancia principal.
  • Cada nodo del grupo de lectura tiene las mismas métricas disponibles que una réplica de lectura de Cloud SQL.
  • Cuando se usa gcloud o la consola de Google Cloud para describir los detalles de un proyecto, se muestra el nombre del grupo de lectura, pero no los nombres de los nodos individuales del grupo de lectura.

Limitaciones

Se aplica la siguiente limitación:

  • Los grupos de lectura solo están disponibles para las instancias de la edición Cloud SQL Enterprise Plus en la nueva arquitectura de red. La instancia principal asociada a un grupo de lectura también debe ser una instancia de la edición Cloud SQL Enterprise Plus.
  • Puedes crear un máximo de siete réplicas de lectura por instancia principal. Este valor puede incluir cualquier cantidad combinada de réplicas de lectura y recuento de nodos del grupo de lectura en una instancia del grupo de lectura. Por ejemplo, una instancia principal puede tener dos réplicas de lectura y un grupo de lectura independiente de cinco réplicas de lectura (nodos del grupo de lectura).
  • El ajuste de escala automático del grupo de lectura no es compatible con las instancias de SQL Server.
  • La recuperación ante desastres avanzada no es compatible con los grupos de lectura. Las instancias principales no pueden usar grupos de lectura ni réplicas en cascada.
  • El tráfico se entrega desde los nodos del grupo de lectura según el estado de la base de datos, pero independientemente de qué tan alto sea el retraso de replicación en ese nodo del grupo de lectura. El tráfico se puede entregar desde un nodo del grupo de lectura con retraso incluso si hay otro nodo del grupo de lectura disponible que no tenga retraso. Se considera que una base de datos está en buen estado si el proceso de la base de datos está en funcionamiento y puede responder consultas, pero no hay ningún requisito sobre la actualidad de los datos que se entregan.
  • No se garantiza que una sola sesión lógica se conecte a varios nodos del grupo de lectura. Es posible que las solicitudes posteriores de una sesión se conecten a un nodo del grupo de lectura que tenga una posición de replicación inferior a la del nodo del grupo de lectura que atendió una solicitud anterior, lo que puede hacer que el estado de la base de datos parezca retroceder en el tiempo.
  • No se admiten los siguientes tipos de actualizaciones:
    • Si bien los grupos de lectura siguen recibiendo actualizaciones de mantenimiento de Cloud SQL, no puedes actualizar tu grupo de lectura ni su instancia principal asociada a una nueva versión principal de la base de datos.
    • Iniciar o detener nodos del grupo de lectura
  • Además de las operaciones que no se admiten en las réplicas de lectura, las siguientes operaciones no se admiten en los grupos de lectura:
  • Los certificados SSL/TLS con una CA compartida o una CA administrada por el cliente no se pueden usar con un grupo de lectura.
  • Un grupo de lectura no se puede replicar en otra instancia, por ejemplo, una réplica en cascada o en otro grupo de lectura.
  • Un grupo de lectura debe replicarse directamente desde una instancia principal. No puede ser una réplica en cascada.
  • Cuando creas o ajustas un grupo de lectura, debes esperar a que finalicen las operaciones anteriores de creación, reducción o expansión asociadas con el grupo de lectura. Esta restricción se aplica a cualquier otro grupo de lectura asociado con la misma instancia principal. Si deseas escalar varios grupos de lectura asociados con la misma instancia principal, debes esperar a que finalicen las operaciones de escalamiento asociadas con el primer grupo de lectura antes de comenzar a escalar el siguiente. Si envías solicitudes simultáneas, es posible que recibas el siguiente error: Operation failed because another operation was already in progress..
  • Solo se puede convertir una réplica zonal ubicada en la misma región que la instancia principal para usarla en un grupo de lectura.
  • Los nodos del grupo de lectura pueden experimentar diferentes niveles de retraso de la replicación, lo que puede generar lecturas incoherentes. Si tu aplicación requiere una alta coherencia de lectura, te recomendamos que escale verticalmente una sola réplica de lectura en lugar de usar un grupo de lectura.
  • Cloud SQL repara automáticamente los nodos del grupo de lectura en las siguientes condiciones:
    • Cuando la instancia está inactiva.
    • Cuando se rompe la replicación.

    En estos casos, si creas accesos adicionales desde la instancia principal, no podrás acceder con ellos después de que se recree el nodo del grupo de lectura. Asegúrate de que el acceso que usas para el extremo de lectura esté disponible desde la instancia principal.

  • Microsoft no admite la replicación de objetos del servidor.

    Todos los objetos a nivel del servidor que crees en una réplica de lectura también se deben crear y administrar en la instancia principal. Estos objetos no se replican automáticamente.

    Este comportamiento se aplica en las siguientes situaciones, aunque la lista no es exhaustiva:

    • Se está reparando un grupo de lectura.
    • Convertir una réplica de lectura en un grupo de lectura
      • Los objetos a nivel del servidor, como los inicios de sesión, se vuelven inaccesibles.
      • Si creas un acceso que existe en la réplica de lectura original, pero no en la instancia principal, el acceso no se replica en el nuevo nodo del grupo de lectura.
    • Convertir un grupo de lectura en una réplica de lectura
      • Si creas un acceso en un grupo de lectura y no en la instancia principal, y luego inhabilitas el grupo de lectura, el acceso dejará de existir.

    Estos son algunos ejemplos de objetos a nivel del servidor que no se replican:

    • Acceso
    • Es la configuración del servidor vinculado.
    • Archivos de auditoría de la base de datos creados por la auditoría de SQL Server.
    • Sesiones de XEvents y sus parámetros de configuración

    Para obtener más información, consulta la documentación de Microsoft.

  • El certificado de encriptación de datos transparente (TDE) está bloqueado para las operaciones de importación y exportación.
  • Siempre debes importar y exportar certificados de TDE desde la instancia principal. Los certificados de TDE se replicarán automáticamente en todas las réplicas de lectura del grupo de lectura, independientemente del tipo de réplica.
  • No se admiten las operaciones de importación y exportación de TDE. Siempre importa el certificado de TDE desde la instancia principal.

¿Qué sigue?