Los grupos de lectura de Cloud SQL admiten el balanceo de cargas para tus cargas de trabajo de lectura grandes.
¿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 cargas de trabajo de lectura grandes. 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 en el grupo de lectura se denomina nodo de grupo de lectura.
Puedes escalar tu grupo de lectura de varias maneras:
- Aumentar o reducir la escala: Escala la capacidad de balanceo de cargas de forma horizontal modificando la cantidad de nodos de grupo de lectura en el grupo de lectura. Cada grupo de lectura admite entre 1 y 20 nodos de grupo de lectura.
- Aumentar o reducir la escala verticalmente: Escala la capacidad de balanceo de cargas de forma vertical mediante la modificación del tipo de máquina asociado con un nodo de grupo de lectura. Una vez definida, la configuración se aplica de manera uniforme en cada nodo de grupo de lectura del grupo de lectura.
Cuando modificas la configuración del nodo de 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 de grupo de lectura del grupo de lectura.
Accede 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 realizadas a través del extremo se redireccionan automáticamente a uno de los nodos de grupo de lectura. Cuando deseas que el grupo de lectura aumente o disminuya la escala, no es necesario volver a configurar las aplicaciones que se conectaron anteriormente a este extremo de lectura único, incluso si puedes crear nodos de grupo de lectura nuevos en el grupo de lectura o borrar los anteriores.
Cada nodo de 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 de grupo de lectura individuales.
Para obtener más información sobre cómo recuperar la información de conexión del grupo de lectura o los nodos de grupo de lectura (ya sean direcciones IP o una cadena de conexión), consulta Visualiza la información del grupo de lectura.
Ajuste de escala automático del grupo de lectura
Para ver cómo configurar tu grupo de lectura para que cambie de tamaño automáticamente y se adapte a las necesidades cambiantes de la carga de trabajo de tu aplicación, consulta Ajuste de escala automático del grupo de lectura.
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 de grupo de lectura del grupo de lectura siempre residen en la misma región, según lo especificado por 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 de menos de un segundo:
- Aumentar o reducir la escala (agregar o quitar nodos de grupo de lectura)
- Aumentar o reducir la escala verticalmente (cambiar el tipo de máquina de los nodos en el 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 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 de grupo de lectura tiene las mismas métricas disponibles que una réplica de lectura de Cloud SQL.
- Cuando se usa
gcloudo la Google Cloud consola para describir los detalles de un proyecto, se muestra el nombre del grupo de lectura, pero no los nombres de los nodos de grupo de lectura individuales. - Si deseas escalar la cantidad de réplicas de lectura más allá de un recuento total de
10, debes restablecer los valores de las
max_wal_sendersymax_replication_slotsmarcas de base de datos en la instancia principal a un valor mayor o igual que la cantidad de réplicas de lectura que deseas usar. Por ejemplo, si tu instancia principal tiene dos réplicas de lectura y dos grupos de lectura de diez réplicas cada uno, debes restablecer las marcas de configuraciónmax_wal_sendersymax_replication_slotsa22o más. Si tu instancia usa PostgreSQL 18, también debes establecer la marcamax_active_replication_originsen22o más.
Limitaciones
Se aplica la siguiente limitación:
- Los grupos de lectura solo están disponibles para instancias de edición de Cloud SQL Enterprise Plus en la nueva arquitectura de red. La instancia principal asociada con un grupo de lectura también debe ser una instancia de edición de Cloud SQL Enterprise Plus.
- El tráfico se entrega desde los nodos de grupo de lectura según si la base de datos está en buen estado, pero independientemente de qué tan alto sea el retraso de replicación en ese nodo de grupo de lectura. El tráfico se puede entregar desde un nodo de grupo de lectura con retraso, incluso si hay otro nodo de 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 qué tan recientes son los datos que se entregan.
- No se garantiza que una sola sesión lógica se conecte a varios nodos de grupo de lectura en el grupo de lectura. Es posible que las solicitudes posteriores en una sesión se conecten a un nodo de grupo de lectura que tenga una posición de replicación más baja (LSN) que el nodo de grupo de lectura que entregó 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 aún reciben actualizaciones de mantenimiento de Cloud SQL, no puedes actualizar tu grupo de lectura a una versión principal nueva 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:
- Habilitar y inhabilitar la replicación
- Promover réplica
- Reiniciar
- Importar
- Exportar
- Conmutación por error
- Volver a encriptar
- Clonar
- No se pueden usar certificados SSL/TLS con una CA compartida o administrada por el cliente con un grupo de lectura.
- Un grupo de lectura no puede replicarse en otra instancia, por ejemplo, una réplica en cascada o otro grupo de lectura.
- Un grupo de lectura debe replicarse directamente desde una instancia principal. No puede ser una réplica en cascada.
- Si deseas convertir una réplica de lectura regional en un grupo de lectura, primero debes convertir la réplica de lectura regional en una réplica de lectura zonal.
- Cuando creas o escalas un grupo de lectura, debes esperar a que finalicen las operaciones anteriores de creación de grupos,
reducción de escala o aumento de escala 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 grupo de lectura. Si emites 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 principal para usarla en un grupo de lectura.
- Si tu aplicación debe conectarse a una réplica de lectura dedicada, por ejemplo, debido a los índices secundarios presentes en una réplica de lectura específica, crea una réplica de lectura de Cloud SQL y úsala en su lugar.