Sobre os pools de leitura

Os pools de leitura do Cloud SQL oferecem suporte ao balanceamento de carga para suas grandes cargas de trabalho de leitura.

O que são pools de leitura?

Um pool de leitura é uma coleção de instâncias de réplica de leitura usadas para distribuir suas grandes cargas de trabalho de leitura. Essas cargas de trabalho podem ser redirecionadas da instância principal para o pool de leitura, reduzindo a carga na instância principal.

Cada réplica de leitura no pool de leitura é chamada de nó do pool de leitura.

É possível escalonar o pool de leitura de várias maneiras:

  • Reduzir ou aumentar escalonamento horizontal: escalone a capacidade de balanceamento de carga horizontalmente modificando o número de nós do pool de leitura. Cada pool de leitura aceita de 1 a 7 nós.
  • Escalonar verticalmente ou reduzir a escala: escalone a capacidade de balanceamento de carga verticalmente modificando o tipo de máquina associado a um nó do pool de leitura. Depois de definida, a configuração é aplicada de maneira uniforme a cada nó do pool de leitura.

Quando você modifica as configurações do nó do pool de leitura, como armazenamento, conectividade ou flags de configuração do banco de dados, as mudanças são aplicadas automaticamente de maneira uniforme em cada nó do pool de leitura.

Acessar um pool de leitura por um único endpoint de leitura

O pool de leitura pode ser acessado por um único endpoint de leitura com um endereço IP imutável. As conexões feitas pelo endpoint são redirecionadas automaticamente para um dos nós do pool de leitura. Quando você quer que o pool de leitura reduza escalonamento horizontal ou escalonar horizontalmente, não é necessário reconfigurar os aplicativos que estavam conectados a esse único endpoint de leitura, mesmo que seja possível criar novos nós de pool de leitura ou excluir os anteriores.

Cada nó do pool de leitura também tem o próprio endereço IP. Embora não seja recomendado como uma abordagem eficiente para acessar seus dados, você pode usar esses endereços IP para resolver problemas de desempenho de nós individuais do pool de leitura.

Para mais informações sobre como recuperar as informações de conexão do pool de leitura ou dos nós do pool de leitura (endereços IP ou uma string de conexão), consulte Ver informações do pool de leitura.

Replicação

A replicação do pool de leitura do Cloud SQL é implementada usando grupos de disponibilidade de escala de leitura do SQL Server.

Para mais informações, consulte Sobre a replicação.

Características do pool de leitura

As seguintes características se aplicam:

  • Um pool de leitura com dois ou mais nós é coberto pelo contrato de nível de serviço (SLA).
  • Os nós do pool de leitura sempre residem na mesma região, conforme especificado pelo usuário.O Google Cloud alterna a residência dos nós do pool de leitura entre todas as zonas da região.
  • Uma instância principal pode ter um ou mais pools de leitura.
  • As seguintes operações causam inatividade em menos de um segundo:
    • Escalonar horizontalmente ou verticalmente (adicionar ou remover nós do pool de leitura).
    • Escalonar para cima ou para baixo (mudar o tipo de máquina dos nós no pool).
    • Converter uma réplica de leitura zonal em um pool de leitura.
  • Um pool de leitura recebe manutenção antes da instância principal, assim como as réplicas de leitura. Assim como as réplicas de leitura, os pools de leitura recebem manutenção durante a janela de manutenção da instância principal.
  • Cada nó do pool de leitura tem as mesmas métricas disponíveis que uma réplica de leitura do Cloud SQL.
  • Ao usar o gcloud ou o console Google Cloud para descrever os detalhes de um projeto, o nome do pool de leitura é listado, mas os nomes dos nós individuais do pool de leitura não são.

Limitações

Considere as seguintes limitações:

  • Os pools de leitura estão disponíveis apenas para instâncias do Cloud SQL Enterprise Plus na nova arquitetura de rede. A instância principal associada a um pool de leitura também precisa ser uma instância do Cloud SQL Enterprise Plus.
  • É possível criar no máximo sete réplicas de leitura por instância principal. Esse valor pode incluir qualquer número combinado de réplicas de leitura e contagem de nós do pool de leitura em uma instância do pool de leitura. Por exemplo, uma instância principal pode ter duas réplicas de leitura e um pool de leitura separado de cinco réplicas de leitura (nós do pool de leitura).
  • O escalonamento automático do pool de leitura não é compatível com instâncias do SQL Server.
  • A recuperação de desastres avançada não é compatível com pools de leitura. As instâncias principais não podem usar pools de leitura e réplicas em cascata.
  • O tráfego é veiculado dos nós do pool de leitura com base na integridade do banco de dados, mas independentemente do atraso de replicação nesse nó. O tráfego pode ser veiculado de um nó do pool de leitura com atraso, mesmo que outro nó do pool de leitura sem atraso esteja disponível. Um banco de dados é considerado íntegro se o processo estiver ativo e puder responder a consultas, mas não há requisitos sobre a atualização dos dados veiculados.
  • Não há garantia de que uma única sessão lógica se conectará a vários nós do pool de leitura. É possível que solicitações posteriores em uma sessão se conectem a um nó do pool de leitura com uma posição de replicação menor do que o nó do pool de leitura que atendeu a uma solicitação anterior, o que pode fazer com que o estado do banco de dados pareça voltar no tempo.
  • Os seguintes tipos de atualizações não são compatíveis:
    • Embora os pools de leitura ainda recebam atualizações de manutenção do Cloud SQL, não é possível atualizar o pool de leitura ou a instância principal associada para uma nova versão principal do banco de dados.
    • Iniciar ou parar nós do pool de leitura.
  • Além das operações que não são compatíveis com réplicas de leitura, as seguintes operações não são compatíveis com pools de leitura:
  • Certificados SSL/TLS com CA compartilhada ou gerenciada pelo cliente não podem ser usados com um pool de leitura.
  • Um pool de leitura não pode ser replicado para outra instância, por exemplo, uma réplica em cascata ou outro pool de leitura.
  • Um pool de leitura precisa ser replicado diretamente de uma instância principal. Não pode ser uma réplica em cascata.
  • Ao criar ou escalonar um pool de leitura, aguarde a conclusão das operações anteriores de criação, reduzir escalonamento horizontal ou escalonar horizontalmente associadas a ele. Essa restrição se aplica a qualquer outro pool de leitura associado à mesma instância principal. Se você quiser escalonar vários pools de leitura associados à mesma instância principal, aguarde a conclusão das operações de escalonamento associadas ao primeiro pool de leitura antes de iniciar o escalonamento do próximo. Se você emitir solicitações simultâneas, poderá receber o seguinte erro: Operation failed because another operation was already in progress..
  • Somente uma réplica zonal localizada na mesma região da instância principal pode ser convertida para uso em um pool de leitura.
  • Os nós do pool de leitura podem ter níveis variados de atraso de replicação, o que pode resultar em leituras inconsistentes. Se o aplicativo exigir alta consistência de leitura, recomendamos escalonar verticalmente uma única réplica de leitura em vez de usar um pool de leitura.
  • O Cloud SQL repara automaticamente os nós do pool de leitura nas seguintes condições:
    • Quando a instância está inativa.
    • Quando a replicação é interrompida.

    Nesses cenários, se você criar outros logins na instância principal, não será possível fazer login usando essas credenciais depois que o nó do pool de leitura for recriado. Verifique se o login usado para o endpoint de leitura está disponível na instância principal.

  • A Microsoft não oferece suporte à replicação de objetos do servidor.

    Todos os objetos no nível do servidor criados em uma réplica de leitura também precisam ser criados e gerenciados na instância principal. Esses objetos não são replicados automaticamente.

    Esse comportamento se aplica aos seguintes cenários, embora não seja uma lista exaustiva:

    • Reparando um pool de leitura.
    • Converter uma réplica de leitura em um pool de leitura.
      • Objetos no nível do servidor, como logins, ficam inacessíveis.
      • Se você criar um login que exista na réplica de leitura original, mas não na instância principal, ele não será replicado para o novo nó do pool de leitura.
    • Converter um pool de leitura em uma réplica de leitura.
      • Se você criar um login em um pool de leitura e não na instância principal e depois desativar o pool de leitura, o login não vai mais existir.

    Confira alguns exemplos de objetos no nível do servidor que não são replicados:

    • Logins.
    • Configuração do servidor vinculado.
    • Arquivos de auditoria de banco de dados criados pela auditoria do SQL Server.
    • Sessões XEvents e as configurações delas.

    Para mais informações, consulte a documentação da Microsoft.

  • O certificado de criptografia transparente de dados (TDE) é bloqueado para operações de importação e exportação.
  • Sempre importe e exporte certificados TDE da instância principal. Os certificados TDE serão replicados automaticamente para todas as réplicas de leitura no pool de leitura, não importa o tipo de réplica.
  • As operações de importação e exportação de TDE não são compatíveis. Sempre importe o certificado TDE da instância principal.

A seguir