Se produce un error de agotamiento del tiempo de espera al conectarse a un cliente de escucha de un grupo de disponibilidad AlwaysOn en un entorno de varias subredes
Este artículo le ayuda a resolver el problema que se produce al conectarse a un agente de escucha de grupo de disponibilidad AlwaysOn de SQL Server en un entorno de varias subredes.
Versión original del producto: SQL Server 2012 Developer, SQL Server 2012 Enterprise, SQL Server 2012 Express, SQL Server 2012 Standard, SQL Server 2012 Web, SQL Server 2012 Enterprise Core
Número de KB original: 2792139
Síntomas
Después de configurar el agente de escucha del grupo de disponibilidad para un grupo de disponibilidad AlwaysOn en Microsoft SQL Server 2012, es posible que no pueda hacer ping al agente de escucha o conectarse a él desde una aplicación.
Por ejemplo, al intentar conectarse a un agente de escucha de SQL Server mediante SQLCMD
, se agota el tiempo de espera de la conexión. Además, recibirá un mensaje de error similar al siguiente:
Sqlcmd: Error: Microsoft SQL Native Client: expira el tiempo de espera de inicio de sesión.
Nota:
Estos síntomas suelen ser intermitentes o relacionados con la conmutación por error del recurso del grupo de disponibilidad.
En la captura de pantalla siguiente se muestra un ejemplo de lo que ocurre al intentar hacer ping al agente de escucha para obtener la disponibilidad de aglisten
. En la captura de pantalla también se muestra una conexión correcta a SQL Server mediante el SQLCMD
comando cuando se incluye el parámetro -M
de conmutación por error de varias subredes .
Nota:
Puede usar el SQLCMD
comando junto con el -M
parámetro tal como se muestra en la captura de pantalla para conectarse al agente de escucha.
Causa
Este problema se produce porque la aplicación usa un proveedor de datos heredado que no admite el nuevo MultiSubnetFailover
parámetro o no está configurado para usar este parámetro.
Este parámetro se admite en versiones más recientes del controlador SQLClient que se incluye con .NET Framework 4 y con versiones posteriores de .NET Framework y se realiza la portabilidad a .NET Framework 3.5.
Nota:
El PING
comando es una herramienta de prueba de conectividad sencilla que no admite el nuevo parámetro.
Solución
Puede usar una de las siguientes resoluciones según corresponda a su caso:
Para resolver esta situación cuando los proveedores de datos admiten el
MultiSubNetFailover
parámetro , agregue elMultiSubNetFailover
parámetro a la cadena de conexión y establézcalo en true.Para resolver esta situación cuando los clientes heredados no pueden usar la
MultiSubnetFailover
propiedad , puede cambiar el valor del agente deRegisterAllProvidersIP
escucha a 0. Para ello, ejecute el siguiente comando desde la interfaz de la línea de comandos de Windows PowerShell:Import-Module FailoverClusters Get-ClusterResource <*Your listener name*>|Set-ClusterParameter RegisterAllProvidersIP 0
Nota:
Después de establecer el RegisterAllProvidersIP
valor en 0, la dirección IP en línea actual debe estar sin registrar desde el servidor DNS y la dirección IP sin conexión debe registrarse en el servidor DNS cuando se produce una conmutación por error. Esto puede provocar un retraso de conexión para la siguiente conmutación por error.
Más información
Al intentar conectarse a un agente de escucha definido en más de una subred, es posible que se produzca un error en la operación si el controlador cliente intenta conectarse mediante una de las direcciones IP sin conexión del agente de escucha.
Cuando se crea un agente de escucha, se designa una dirección IP para cada subred única en la que se hospeda una réplica de grupo de disponibilidad. Por ejemplo, si se crea un agente de escucha para un grupo de disponibilidad que tiene réplicas que existen en dos subredes, se definen dos direcciones IP en el agente de escucha. Una dirección la usa una aplicación que puede conectarse a una instancia de SQL Server en la subred 1 y la otra dirección se usa cuando una aplicación se conecta a una instancia de SQL Server en la subred 2.
En segundo plano, el agente de escucha crea un recurso de punto de acceso de cliente del clúster de Windows. Una de sus propiedades es RegisterAllProvidersIP
. Cuando se crea un agente de escucha, se establece en 1 y todas las direcciones IP del agente de escucha se registran en el servidor DNS. Esta configuración proporciona un tiempo de reconexión reducido para los clientes.
Dado que el registro DNS contiene todas las direcciones IP, un cliente que intenta conectarse al agente de escucha debe saber cómo controlar esta situación. El MultiSubnetFailover
parámetro permite al controlador cliente probar las conexiones en paralelo a todas las direcciones IP del agente de escucha. Sin el MultiSubnetFailover
parámetro , el controlador cliente intentará conectarse secuencialmente a todas las direcciones IP del agente de escucha. Las conexiones secuenciales pueden provocar un tiempo de inicio de sesión largo o tiempos de espera de inicio de sesión.
Nota:
El problema que se menciona en este artículo también afecta a los entornos de SharePoint que están configurados para usar una réplica de solo lectura secundaria del grupo de disponibilidad AlwaysOn. Para resolver este problema, realice cualquier acción que se aplique a la versión de SharePoint:
Para SharePoint 2007: esto se clasifica como una aplicación heredada. Por lo tanto, SharePoint 2007 no se puede configurar para usar el
MultiSubnetFailover
parámetro . En su lugar, debe usar el comando de Windows PowerShell que se describe en la sección Resolución .Para SharePoint 2010: los paquetes de actualización acumulativa ahora están disponibles que agregan compatibilidad con el
MultiSubnetFailover
parámetro . Para obtener más información sobre los paquetes de actualización, consulte el siguiente artículo:
Referencias
Compatibilidad de SqlClient para alta disponibilidad y recuperación ante desastres
Configuración de un agente de escucha para un grupo de disponibilidad Always On (SQL Server)
Agrupación en clústeres de varias subredes de SQL Server (SQL Server)
Tiempos de expiración de conexión en un grupo de disponibilidad con varias subredes.