Tipos de conexões de cliente com as réplicas em um grupo de disponibilidade Always On

Aplica-se a: SQL Server

Em um grupo de disponibilidade AlwaysOn, você pode configurar uma ou mais réplicas de disponibilidade para permitir conexões somente leitura quando elas estiverem sendo executadas na função secundária (ou seja, executando como uma réplica secundária). Você também pode configurar cada réplica de disponibilidade para permitir ou excluir conexões somente leitura quando ela estiver sendo executada na função primária (ou seja, em execução como uma réplica primária).

Para facilitar o acesso de clientes aos bancos de dados primário ou secundário de um determinado grupo de disponibilidade, você deve definir um ouvinte de grupo de disponibilidade. Por padrão, o ouvinte do grupo de disponibilidade direciona as conexões de entrada para a réplica primária. No entanto, você pode configurar um grupo de disponibilidade para suportar o roteamento somente leitura que permite que seu ouvinte de grupo de disponibilidade redirecione as solicitações de conexão de aplicativos de tentativa de leitura a uma réplica secundária legível. Para obter informações, veja Configurar o roteamento somente leitura para um grupo de disponibilidade (SQL Server).

Durante um failover, uma réplica secundária faz a transição para a função primária e a réplica primária antiga faz a transição para a réplica secundária. Durante o processo de failover, todas as conexões de cliente com a réplica primária e as réplicas secundárias são terminadas. Após o failover, quando um cliente se reconecta ao ouvinte de grupo de disponibilidade, o ouvinte reconecta o cliente à nova réplica primária, com exceção de uma solicitação conexão de tentativa de leitura. Se o roteamento somente leitura estiver configurado nas instâncias de cliente e de servidor que hospedam a nova réplica primária e pelo menos em uma réplica secundária legível, as solicitações de conexão de tentativa de leitura serão redirecionadas a uma réplica secundária com suporte para o tipo de acesso de conexão exigido pelo cliente. Para garantir uma experiência de cliente amigável depois de um failover, é importante configurar o acesso de conexão para as funções secundárias e primária de cada réplica de disponibilidade.

Observação

Para obter informações sobre o ouvinte do grupo de disponibilidade, que manipula as solicitações de conexão do cliente, confira Ouvintes do grupo de disponibilidade, conectividade de cliente e failover de aplicativo (SQL Server).

Tipos de acesso de conexão com suporte da função secundária

A função secundária dá suporte a três alternativas para conexões de cliente, da seguinte maneira:

Nenhuma conexão
Nenhuma conexão de usuário é permitida. Os bancos de dados secundários não estão disponíveis para acesso de leitura. Esse é o comportamento padrão na função secundária.

Conexões somente de intenção de leitura
Os bancos de dados secundários estão disponíveis apenas para a conexão para a qual a propriedade de conexão Application Intent está definida como ReadOnly (conexões de intenção de leitura).

Para obter mais informações sobre essa propriedade de conexão, consulte Suporte do SQL Server Native Client à alta disponibilidade e recuperação de desastre.

Permitir qualquer conexão somente leitura
Todos os bancos de dados secundários estão disponíveis para conexões de acesso de leitura. Essa opção permite a conexão de clientes com versão inferior.

Para obter mais informações, confira Configurar o acesso somente leitura em uma réplica de disponibilidade (SQL Server).

Tipos de acesso de conexão com suporte da função primária

A função primária dá suporte a duas alternativas para conexões de cliente, da seguinte maneira:

Todas as conexões são permitidas
As conexões de leitura/gravação e somente leitura são permitidas nos bancos de dados primários. Esse é o comportamento padrão para a função primária.

Permitir apenas conexões de leitura/gravação
Quando a propriedade de conexão Application Intent está definida como ReadWrite ou não está definida, a conexão é permitida. As conexões para as quais a palavra chave da cadeia de conexão Application Intent está definida como ReadOnly não são permitidas. Permitir apenas conexões de leitura/gravação pode ajudar a impedir que os clientes conectem uma carga de trabalho de intenção de leitura à réplica primária por engano.

Para obter mais informações sobre essa propriedade de conexão, consulte Using Connection String Keywords with SQL Server Native Client.

Para obter mais informações, confira Configurar o acesso somente leitura em uma réplica de disponibilidade (SQL Server).

Como a configuração de acesso de conectividade afeta a conectividade de clientes

As configurações de acesso de conexão de uma réplica determinam se uma tentativa de conexão é reprovada ou tem êxito. A tabela a seguir resume quando uma determinada tentativa de conexão é reprovada ou tem êxito para cada configuração de acesso de conexão.

Função da Réplica Acesso de conexão com suporte na réplica Tentativa de conexão Resultado da tentativa de conexão
Secundário Tudo Intenção de leitura, leitura/gravação ou nenhuma intenção de conexão especificada Êxito
Secundário Nenhum (este é o comportamento padrão da função secundária). Intenção de leitura, leitura/gravação ou nenhuma intenção de conexão especificada Falha
Secundário Tentativa de leitura somente Intenção de leitura Êxito
Secundário Tentativa de leitura somente Intenção de leitura/gravação ou nenhuma intenção de conexão especificada Falha
Primário Tudo (esse é o comportamento padrão da função primária). Intenção de somente leitura, leitura/gravação ou nenhuma intenção de conexão especificada Êxito
Primário Leitura-gravação Tentativa de leitura somente Falha
Primário Leitura-gravação Intenção de leitura/gravação ou nenhuma intenção de conexão especificada Êxito

Para obter informações sobre como configurar um grupo de disponibilidade para aceitar conexões de cliente às suas réplicas, confira Ouvintes do grupo de disponibilidade, conectividade de cliente e failover de aplicativo (SQL Server).

Exemplo de configuração de acesso de conexão

Dependendo de como as diferentes réplicas de disponibilidade são configuradas para acesso de conexão, o suporte para conexões de clientes pode ser alterado depois que um grupo de disponibilidade sofre failover. Por exemplo, considere um grupo de disponibilidade para o qual o relatório é executado em réplicas secundárias de confirmação assíncrona remotas. Todos os aplicativos somente leitura dos bancos de dados deste grupo de disponibilidade definem sua propriedade de conexão Application Intent como ReadOnly. Portanto, todas as conexões somente leitura são conexões de intenção de leitura.

Este grupo de disponibilidade de exemplo possui duas réplicas da confirmação síncrona no centro de computação principal e duas réplicas da confirmação assíncrona em um site de satélite. Para a função primária, todas as réplicas são configuradas para acesso de leitura/gravação, o que impede conexões de intenção de leitura com a réplica primária em todas as situações. A função secundária de confirmação síncrona usa a configuração de acesso de conexão padrão ("nenhuma"), que impede todas as conexões de cliente sob a função secundária. Em comparação, as réplicas de confirmação assíncronas são configuradas para permitir conexões de intenção de leitura sob a função secundária. A tabela a seguir resume essa configuração de exemplo:

Réplica Modo de confirmação Função inicial Acesso de conexão para a função secundária Acesso de conexão para a função primária
Replica1 Síncrona Primário Nenhum Leitura-gravação
Replica2 Síncrona Secundário Nenhum Leitura-gravação
Replica3 Assíncrona Secundário Somente tentativa de leitura Leitura-gravação
Replica4 Assíncrona Secundário Tentativa de leitura somente Leitura-gravação

Normalmente, neste cenário de exemplo, os failovers ocorrem apenas entre as réplicas de confirmação síncrona e imediatamente após o failover, os aplicativos de intenção de leitura podem se reconectar a uma das réplicas secundárias de confirmação assíncrona. No entanto, quando ocorre um desastre no centro de computação principal, as duas réplicas de confirmação síncrona são perdidas. O administrador de banco de dados no site de satélite responde executando um failover manual forçado em uma réplica secundária da confirmação assíncrona. Os bancos de dados secundários na réplica secundária restante são suspensos pelo failover forçado, tornando-os indisponíveis para cargas de trabalho somente leitura. A nova réplica primária, que está configurada para conexões de leitura/gravação, impede que a carga de trabalho de intenção de leitura erudita compita com a carga de trabalho de leitura/gravação. Isso significa que, até que o administrador de banco de dados retome os bancos de dados secundários na réplica secundária restante de confirmação assíncrona, os clientes com intenção de leitura não podem se conectar a qualquer réplica de disponibilidade.

Related Tasks

Conteúdo relacionado

Consulte Também

Visão geral dos Grupos de Disponibilidade AlwaysOn (SQL Server)
Ouvintes do grupo de disponibilidade, conectividade de cliente e failover de aplicativo (SQL Server)
Estatísticas