Compartilhar via


Pool de conexões

A conexão a uma fonte de dados pode ser demorada. Para minimizar o custo da abertura de conexões, o ADO.NET usa uma técnica de otimização chamada pool de conexões, que minimiza o custo de abrir e fechar conexões repetidamente. O pool de conexões é tratado de forma diferente para os provedores de dados do .NET Framework. Embora o pool de conexões melhore o desempenho e a utilização de recursos, vários fatores podem influenciar sua eficiência dependendo do ambiente e da configuração do banco de dados:

  • limites de conexão e restrições de recursos: Em ambientes de banco de dados, os limites de conexão geralmente são vinculados a camadas de serviço ou configurações de recursos. Por exemplo, o Banco de Dados SQL do Azure define limites de conexão com base na camada de serviço selecionada, enquanto a Instância Gerenciada de SQL do Azure impõe limites com base em recursos alocados, como CPU, memória ou vCores. Quando as configurações do pool de conexões excedem esses limites, os aplicativos podem experimentar conexões rejeitadas, limitação ou desempenho degradado.

  • Métodos de Autenticação: mecanismos de autenticação baseados em token, como a autenticação por meio do Microsoft Entra ID, podem afetar o agrupamento de conexões devido à expiração do token. Tokens expirados podem invalidar conexões no pool, interrompendo a reutilização. Esse comportamento ocorre em sistemas de banco de dados locais e baseados em nuvem que usam protocolos de autenticação modernos.

  • Latência de Rede e Pontos de Extremidade: latência de rede e configurações de ponto de extremidade podem influenciar a eficiência do pool de conexões. Os pontos de extremidade públicos, comumente usados em bancos de dados hospedados na nuvem, normalmente introduzem maior latência em comparação com conexões privadas ou diretas. Em aplicativos nativos de nuvem com endereçamento IP dinâmico, a reutilização de conexão poderá ser interrompida se as regras de firewall não forem atualizadas para acomodar a alteração de endereços IP.

  • Requisitos de criptografia de : bancos de dados que exigem criptografia TLS/SSL requerem alinhamento entre configurações de agrupamento de conexões e configurações de criptografia. Por exemplo, omitir parâmetros de criptografia necessários em cadeias de conexão, como Encrypt=True, pode levar a falhas de conexão, reduzindo a eficiência do pool.

  • Resolução DNS: pontos de extremidade privados e configurações de DNS personalizadas podem representar desafios para o agrupamento de conexões. Configurações de DNS incorretas ou inconsistentes podem atrasar ou bloquear o estabelecimento da conexão, afetando o desempenho e a confiabilidade da reutilização da conexão. Isso é especialmente relevante em ambientes com configurações de nuvem híbrida ou privada.

Nesta seção

Pool de Conexões do SQL Server (ADO.NET)
Fornece uma visão geral do pool de conexões e descreve como o pool de conexões funciona no SQL Server.

OLE DB, ODBC e Pool de Conexões Oracle
Descreve o pool de conexões para o Provedor de Dados do .NET Framework para OLE DB, o Provedor de Dados do .NET Framework para ODBC e o Provedor de Dados do .NET Framework para Oracle.

Consulte também