Écouteurs de groupe de disponibilité, connectivité client et basculement d'application (SQL Server)
Cette rubrique contient des informations sur les éléments à prendre en compte en matière de connectivité client Groupes de disponibilité AlwaysOn et de fonctionnalité de basculement d'application.
[!REMARQUE]
Pour la majorité des configurations habituelles d'écouteur, vous pouvez créer le premier écouteur de groupe de disponibilité simplement à l'aide d'instructions Transact-SQL ou d'applets de commande PowerShell. Pour plus d'informations, consultez Tâches associées, plus loin dans cette rubrique.
Dans cette rubrique :
Écouteurs de groupe de disponibilité
Utilisation d'un écouteur pour se connecter au réplica principal
Utilisation d'un écouteur pour se connecter à un réplica secondaire en lecture seule (routage en lecture seule)
Pour configurer des réplicas de disponibilité pour le routage en lecture seule
Intention de l'application en lecture seule et routage en lecture seule
Contournement des écouteurs de groupe de disponibilité
Comportement des connexions clientes lors du basculement
Prise en charge de basculements de sous-réseaux multiples de groupe de disponibilité
Écouteurs de groupe de disponibilité et certificats SSL
Écouteurs de groupe de disponibilité et noms de principal de serveur (SPN)
Tâches associées
Contenu connexe
Écouteurs de groupe de disponibilité
Vous pouvez fournir la connectivité client à la base de données d'un groupe de disponibilité donné en créant un écouteur de groupe de disponibilité. Un écouteur de groupe de disponibilité est un nom de réseau virtuel (VNN) auquel les clients peuvent se connecter afin d'accéder à une base de données dans un réplica principal ou secondaire d'un groupe de disponibilité AlwaysOn. Un écouteur de groupe de disponibilité permet à un client de se connecter à un réplica de disponibilité sans connaître le nom de l'instance physique de SQL Server à laquelle il se connecte. Il est inutile de modifier la chaîne de connexion du client pour se connecter à l'emplacement actuel du réplica principal.
Un écouteur de groupe de disponibilité consiste en un nom d'écouteur DNS (Domain Name System), en une désignation de port d'écoute et en une ou plusieurs adresses IP. Seul le protocole TCP est pris en charge par l'écouteur de groupe de disponibilité. Le nom DNS de l'écouteur doit également être unique dans le domaine et dans NetBIOS. Lorsque vous créez un nouvel écouteur de groupe de disponibilité, il devient une ressource de cluster avec un nom de réseau virtuel (VNN) associé, une adresse IP virtuelle (VIP) et une dépendance de groupe de disponibilité. Un client utilise le nom DNS pour résoudre le nom VNN en plusieurs adresses IP et tente ensuite de se connecter à chaque adresse, jusqu'à ce qu'une demande de connexion réussisse ou jusqu'à ce que la requête de connexion expire.
Si le routage en lecture seule est configuré pour un ou plusieurs réplicas secondaires lisibles, les connexions clientes d'intention de lecture du réplica principal sont redirigées vers un réplica secondaire lisible. Par ailleurs, si le réplica principal est mis hors connexion sur une instance de SQL Server et un nouveau réplica principal passe en ligne sur une autre instance de SQL Server, l'écouteur de groupe de disponibilité permet aux clients de se connecter au nouveau réplica principal.
Pour obtenir des informations essentielles sur les écouteurs de groupe de disponibilité, consultez Créer ou configurer un écouteur de groupe de disponibilité (SQL Server).
Dans cette section :
Configuration de l'écouteur de groupe de disponibilité
Sélection d'un port d'écoute de groupe de disponibilité
Configuration de l'écouteur de groupe de disponibilité
Un écouteur de groupe de disponibilité est défini par les élément suivants :
Un nom DNS unique.
Ce nom est aussi appelé un nom de réseau virtuel (VNN). Les règles d'attribution de noms Active Directory pour les noms d'hôte DNS s'appliquent. Pour plus d'informations, consultez l'article Conventions d'affectation de noms dans Active Directory pour les ordinateurs, les domaines, les sites et les unités d'organisation de la Base de connaissances.Une ou plusieurs adresses IP virtuelles (VIP)
Les adresses IP virtuelles sont configurées pour un ou plusieurs sous-réseaux vers lesquels le groupe de disponibilité peut basculer.Configuration de l'adresse IP
Pour un écouteur de groupe de disponibilité donné, l'adresse IP utilise le protocole DHCP (Dynamic Host Configuration Protocol) ou une ou plusieurs adresses IP statiques.Protocole DHCP (Dynamic Host Configuration Protocol)
Vous pouvez configurer toutes les adresses IP d'écouteur de groupe de disponibilité en vue d'utiliser le protocole DHCP (Dynamic Host Configuration Protocol) si un groupe de disponibilité réside sur un même sous-réseau. Pour les environnements de préproduction, le protocole DHCP permet une installation facile pour un groupe de disponibilité qui n'a pas besoin de la fonctionnalité de récupération d'urgence vers un site distant sur un sous-réseau distinct. Toutefois, nous déconseillons d'utiliser DHCP en même temps qu'un écouteur de groupe de disponibilité dans un environnement de production. En effet, en cas d'arrêt du système, si le bail IP DHCP expire, il faudra consacrer du temps supplémentaire pour réinscrire la nouvelle adresse IP DHCP associée au nom DNS de l'écouteur. Ce temps supplémentaire va provoquer l'échec de la connexion cliente.
Adresses IP statiques
Dans les environnements de production, nous conseillons que les écouteurs de groupe de disponibilité utilisent des adresses IP statiques. De plus, dans le cas où vos groupes de disponibilité s'étendent sur plusieurs sous-réseaux dans un domaine de plusieurs sous-réseaux, un écouteur de groupe de disponibilité doit utiliser des adresses IP statiques.
Les configurations réseau hybrides et le recours au protocole DHCP sur plusieurs sous-réseaux ne sont pas pris en charge pour les écouteurs de groupe de disponibilité. Cela est dû au fait que, lorsqu'un basculement a lieu, une adresse IP dynamique peut expirer ou être libérée, ce qui compromet la haute disponibilité globale.
Sélection d'un port d'écoute de groupe de disponibilité
Lors de la configuration d'un écouteur de groupe de disponibilité, vous devez indiquer un port. Vous pouvez configurer le port par défaut sur 1433, afin de permettre de simplifier les chaînes de connexion du client. Si vous utilisez 1433, vous n'avez pas besoin d'indiquer un numéro de port dans une chaîne de connexion. De plus, étant donné que chaque écouteur de groupe de disponibilité portera un nom de réseau virtuel distinct, chaque écouteur de groupe de disponibilité configuré sur un même WSFC pourra être configuré pour référencer le même port par défaut 1433.
Vous pouvez également indiquer un port d'écoute non standard ; toutefois, cela signifie que vous devrez également spécifier explicitement un port cible dans votre chaîne de connexion lors de chaque connexion à l'écouteur de groupe de disponibilité. Vous devrez également ouvrir l'autorisation sur le pare-feu pour le port non standard.
Si vous utilisez le port par défaut 1433 comme nom VNN de l'écouteur du groupe de disponibilité, vous devez toujours vérifier qu'aucun autre service sur le nœud de cluster n'utilise ce port ; dans le cas contraire, cela provoquerait un conflit de ports.
Si l'une des instances de SQL Server écoute déjà sur le port TCP 1433 par l'intermédiaire de l'écouteur d'instance et qu'il n'existe aucun autre service (instances supplémentaires de SQL Server comprises) sur l'ordinateur écoutant sur le port 1433, cela ne provoque pas un conflit de ports avec l'écouteur du groupe de disponibilité. Cela est dû au fait que l'écouteur du groupe de disponibilité peut partager le même port TCP au sein du même processus de service. Toutefois, plusieurs instances de SQL Server (côte à côte) ne doivent pas être configurées pour écouter sur le même port.
[Haut de la page]
Utilisation d'un écouteur pour se connecter au réplica principal
Pour utiliser un écouteur de groupe de disponibilité pour la connexion au réplica principal en vue de l'accès en lecture-écriture, la chaîne de connexion spécifie le nom DNS de l'écouteur de groupe de disponibilité. Si un réplica principal de groupe de disponibilité se transforme en nouveau réplica, les connexions existantes qui utilisent le nom réseau d'un écouteur de groupe de disponibilité sont déconnectées. Les nouvelles connexions à l'écouteur du groupe de disponibilité sont ensuite dirigées vers le nouveau réplica principal. Voici un exemple de chaîne de connexion de base pour le fournisseur ADO.NET (System.Data.SqlClient) :
Server=tcp: AGListener,1433;Database=MyDB;IntegratedSecurity=SSPI
Vous pouvez néanmoins choisir de référencer directement l'instance du nom SQL Server des réplicas principaux ou secondaires au lieu d'utiliser le nom du serveur de l'écouteur du groupe de disponibilité ; toutefois, si vous choisissez d'agir ainsi, les nouvelles connexions ne seront plus dirigées automatiquement vers le réplica principal actuel. Vous perdrez également l'avantage du routage en lecture seule.
[Haut de la page]
Utilisation d'un écouteur pour se connecter à un réplica secondaire en lecture seule (routage en lecture seule)
Le routage en lecture seule fait référence à la capacité de SQL Server d'acheminer les connexions entrantes à un écouteur de groupe de disponibilité vers un réplica secondaire qui est configuré pour autoriser des charges de travail en lecture seule. Une connexion entrante faisant référence à un nom d'écouteur de groupe de disponibilité peut automatiquement être acheminée vers un réplica en lecture seule si les conditions suivantes sont réunies :
Au moins un réplica secondaire est défini sur l'accès en lecture seule, et chaque réplica secondaire en lecture seule et le réplica principal sont configurés pour prendre en charge le routage en lecture seule. Pour plus d'informations, consultez Pour configurer des réplicas de disponibilité pour le routage en lecture seule, plus loin dans cette section.
La chaîne de connexion fait référence à un écouteur de groupe de disponibilité, et l'intention de l'application de la connexion entrante est définie en lecture seule (par exemple, à l'aide du mot clé Application Intent**=**ReadOnly dans les chaînes de connexion ODBC ou OLEDB ou dans les attributs ou les propriétés de connexion). Pour plus d'informations, consultez Intention de l'application en lecture seule et routage en lecture seule, plus loin dans cette section.
Pour configurer des réplicas de disponibilité pour le routage en lecture seule
Un administrateur de base de données doit configurer les réplicas de disponibilité comme suit :
Pour chaque réplica de disponibilité à configurer comme réplica secondaire accessible en lecture, un administrateur de base de données doit configurer les paramètres suivants, qui prennent effet uniquement sous le rôle secondaire :
L'accès à la connexion doit avoir la valeur « tous » ou « lecture seule ».
L'URL de routage en lecture seule doit être spécifiée.
Pour chacun de ces réplicas, une liste de routage en lecture seule doit être spécifiée pour le rôle principal. Spécifiez un ou plusieurs noms de serveur comme cibles de routage.
Tâches associées
Configurer l'accès en lecture seule sur un réplica de disponibilité (SQL Server)
Configurer le routage en lecture seule pour un groupe de disponibilité (SQL Server)
Intention de l'application en lecture seule et routage en lecture seule
La propriété de chaîne de connexion de l'intention d'application exprime le souhait de l'application cliente d'être redirigée vers une version en lecture-écriture ou en lecture seule d'une base de données de groupe de disponibilité. Pour utiliser le routage en lecture seule, un client doit utiliser une intention d'application en lecture seule dans la chaîne de connexion pour la connexion à l'écouteur de groupe de disponibilité. Sans intention d'application en lecture seule, les connexions à l'écouteur de groupe de disponibilité sont dirigées vers la base de données sur le réplica principal.
L'attribut d'intention d'application est stocké dans la session du client lors de la connexion ; l'instance de SQL Server traite ensuite cette intention et détermine ce qu'il faut faire, selon la configuration du groupe de disponibilité et l'état en lecture-écriture actuel de la base de données cible dans le réplica secondaire.
Voici un exemple de chaîne de connexion pour le fournisseur ADO.NET (System.Data.SqlClient) qui indique l'intention d'application en lecture seule :
Server=tcp:AGListener,1433;Database=AdventureWorks;IntegratedSecurity=SSPI;ApplicationIntent=ReadOnly
Dans cet exemple de chaîne de connexion, le client tente de se connecter à un écouteur de groupe de disponibilité nommé AGListener sur le port 1433 (vous pouvez aussi omettre le port si l'écouteur du groupe de disponibilité écoute sur le port 1433). La chaîne de connexion a la propriété ApplicationIntent définie sur ReadOnly, ce qui en fait une chaîne de connexion d'intention de lecture. Sans ce paramètre, le serveur n'aurait pas essayé un routage en lecture seule de la connexion.
La base de données primaire du groupe de disponibilité traite la demande de routage en lecture seule entrante et tente de localiser un réplica en ligne et en lecture seule joint au réplica principal et configuré pour le routage en lecture seule. Le client reçoit les informations de connexion depuis le serveur de réplica principal et se connecte au réplica en lecture seule identifié.
Notez que l'intention de l'application peut être envoyée depuis un pilote client vers une instance de bas niveau de SQL Server. Dans ce cas, l'intention de l'application en lecture seule est ignorée et la connexion se déroule normalement.
Vous pouvez contourner le routage en lecture seule en ne définissant pas la propriété de connexion d'intention d'application avec la valeur ReadOnly (en l'absence de spécification, la valeur par défaut est ReadWrite pendant la connexion) ou en effectuant une connexion directe à l'instance du réplica principal de SQL Server au lieu d'utiliser le nom de l'écouteur du groupe de disponibilité. Le routage en lecture seule n'a pas lieu non plus si vous vous connectez directement à un réplica en lecture seule.
Tâches associées
[Haut de la page]
Contournement des écouteurs de groupe de disponibilité
Alors que les écouteurs de groupe de disponibilité permettent la prise en charge de la redirection de basculement et le routage en lecture seule, les connexions clientes ne sont pas requises pour les utiliser. Une connexion cliente peut également faire directement référence à l'instance de SQL Server au lieu de se connecter à l'écouteur du groupe de disponibilité.
Pour l'instance de SQL Server, cela ne fait aucune différence si une connexion est établie à l'aide de l'écouteur du groupe de disponibilité ou avec un autre point de terminaison d'instance. L'instance de SQL Server vérifie l'état de la base de données ciblée, puis autorise ou interdit la connectivité, selon la configuration du groupe de disponibilité et l'état actuel de la base de données sur l'instance. Par exemple, si une application cliente se connecte directement à une instance de port SQL Server et se connecte à une base de données cible hébergée dans un groupe de disponibilité, et que la base de données cible se trouve dans l'état primaire et en ligne, la connectivité aboutit. Si la base de données cible est hors connexion ou dans un état de transition, la connectivité à la base de données échoue.
Autrement, lors d'une migration depuis une mise en miroir de bases de données vers Groupes de disponibilité AlwaysOn, les applications peuvent spécifier la chaîne de connexion de mise en miroir de bases de données dans la mesure où il existe un seul réplica secondaire et qu'il n'autorise pas les connexions utilisateur. Pour plus d'informations, consultez Utilisation des chaînes de connexion de mise en miroir de bases de données avec des groupes de disponibilité, plus loin dans cette section.
Utilisation de chaînes de connexion de mise en miroir de bases de données avec des groupes de disponibilité
Si un groupe de disponibilité possède uniquement un réplica secondaire et n'est pas configuré pour autoriser l'accès en lecture au réplica secondaire, les clients peuvent se connecter au réplica principal à l'aide d'une chaîne de connexion de mise en miroir de bases de données. Cette approche peut être utile lors de la migration d'une application existante depuis la mise en miroir de bases de données vers un groupe de disponibilité, tant que vous limitez le groupe de disponibilité à deux réplicas de disponibilité (un réplica principal et un réplica secondaire). Si vous ajoutez des réplicas secondaires supplémentaires, vous devrez créer un écouteur de groupe de disponibilité pour le groupe de disponibilité et mettre à jour vos applications pour utiliser le nom DNS de l'écouteur du groupe de disponibilité.
Lors de l'utilisation de chaînes de connexion de mise en miroir de bases de données, le client peut soit utiliser SQL Server Native Client, soit le fournisseur de données .NET Framework pour SQL Server. La chaîne de connexion fournie par un client doit fournir au minimum le nom d'une instance de serveur, le nom du partenaire initial, pour identifier l'instance de serveur qui héberge initialement le réplica de disponibilité auquel vous envisagez de vous connecter. Éventuellement, la chaîne de connexion peut également fournir le nom d'une autre instance de serveur, le nom du partenaire de basculement, pour identifier l'instance de serveur qui héberge initialement le réplica secondaire comme nom de partenaire de basculement.
Pour plus d'informations sur les chaînes de connexion de mise en miroir de bases de données, consultez Connecter des clients à une session de mise en miroir de bases de données (SQL Server).
[Haut de la page]
Comportement des connexions clientes lors du basculement
Lorsqu'un basculement de groupe de disponibilité se produit, les connexions persistantes existantes au groupe de disponibilité prennent fin et le client doit établir une nouvelle connexion afin de continuer à utiliser la même base de données primaire ou base de données secondaire en lecture seule. Lorsqu'un basculement se produit côté serveur, la connectivité au groupe de disponibilité peut échouer, forçant l'application cliente à réessayer une nouvelle connexion jusqu'à ce que le serveur principal soit entièrement remis en ligne.
Si le groupe de disponibilité revient en ligne pendant une tentative de connexion d'une application cliente, mais avant l'expiration du délai d'attente de connexion, le pilote client peut se connecter avec succès au cours de l'une de ses tentatives de reprise interne et aucune erreur ne sera visible dans l'application dans ce cas.
[Haut de la page]
Prise en charge de basculements de sous-réseaux multiples de groupe de disponibilité
Si vous utilisez des bibliothèques clientes qui prennent en charge l'option de connexion MultiSubnetFailover dans la chaîne de connexion, vous pouvez optimiser le basculement du groupe de disponibilité vers un sous-réseau différent en définissant MultiSubnetFailover sur « True » ou « Yes », selon la syntaxe du fournisseur que vous utilisez.
[!REMARQUE]
Nous vous recommandons de définir ce paramètre à la fois pour les connexions à un seul ou à plusieurs sous-réseaux aux écouteurs de groupes de disponibilité et aux noms d'instance de cluster de basculement SQL Server. L'activation de cette option ajoute des optimisations supplémentaires, même pour les scénarios de sous-réseau unique.
L'option de connexion MultiSubnetFailover fonctionne uniquement avec le protocole réseau TCP et elle est prise en charge uniquement lors de la connexion à un écouteur de groupe de disponibilité et pour n'importe quel nom de réseau virtuel se connectant à SQL Server 2012.
Voici un exemple de chaîne de connexion du fournisseur ADO.NET (System.Data.SqlClient) qui permet le basculement de plusieurs sous-réseaux :
Server=tcp:AGListener,1433;Database=AdventureWorks;IntegratedSecurity=SSPI; MultiSubnetFailover=True
L'option de connexion MultiSubnetFailover doit être définie avec la valeur True même si le groupe de disponibilité s'étend sur un seul sous-réseau. Cela vous permet de préconfigurer de nouveaux clients afin de prendre en charge la future couverture de sous-réseaux, sans recourir à de futures modifications de la chaîne de connexion du client. Par ailleurs, cela permet d'optimiser les performances de basculement pour les basculements au sein d'un seul sous-réseau. Lorsque l'option de connexion MultiSubnetFailover n'est pas obligatoire, elle offre l'avantage d'un basculement de sous-réseau plus rapide. Cela est dû au fait que le pilote client essaie d'ouvrir un socket TCP pour chaque adresse IP en parallèle associée au groupe de disponibilité. Le pilote client attend une réponse correcte de la première adresse IP et, ceci fait, l'utilise pour la connexion.
[Haut de la page]
Écouteurs de groupe de disponibilité et certificats SSL
Lors de la connexion à un écouteur de groupe de disponibilité, si les instances participantes de SQL Server utilisent des certificats SSL en même temps que le chiffrement de session, le pilote client de la connexion doit prendre en charge le nom SAN (Subject Alternate Name) dans le certificat SSL afin de forcer le chiffrement. La prise en charge de pilotes SQL Server pour le nom SAN de certificat est planifiée pour ADO.NET (SqlClient), Microsoft JDBC et SQL Native Client (SNAC).
Un certificat X.509 doit être configuré pour chaque nœud serveur participant dans le cluster de basculement, avec une liste de tous les écouteurs de groupe de disponibilité définis dans le nom SAN du certificat.
Par exemple, si le WSFC dispose de trois écouteurs de groupe de disponibilité avec les noms AG1_listener.Adventure-Works.com, AG2_listener.Adventure-Works.com et AG3_listener.Adventure-Works.com, le nom SAN du certificat doit être défini comme suit :
CN = ServerFQDN
SAN = ServerFQDN,AG1_listener.Adventure-Works.com, AG2_listener.Adventure-Works.com, AG3_listener.Adventure-Works.com
[Haut de la page]
Écouteurs de groupe de disponibilité et noms de principal de serveur (SPN)
Un nom de principal de serveur (SPN) doit être configuré dans Active Directory par un administrateur de domaine pour chaque nom d'écouteur de groupe de disponibilité afin d'activer Kerberos pour la connexion cliente à l'écouteur du groupe de disponibilité. Lors de l'inscription du nom SPN, vous devez utiliser le compte de service de l'instance de serveur qui héberge le réplica de disponibilité. Pour que le SPN fonctionne sur tous les réplicas, le même compte de service doit être utilisé pour toutes les instances du cluster WSFC qui héberge le groupe de disponibilité.
Utilisez l'outil de ligne de commande setspn de Windows pour configurer le SPN. Par exemple, pour configurer un SPN pour un groupe de disponibilité nommé AG1listener.Adventure-Works.com hébergé dans un ensemble d'instances de SQL Server, toutes configurées pour s'exécuter sous le compte de domaine corp/svclogin2 :
setspn -A MSSQLSvc/AG1listener.Adventure-Works.com:1433 corp/svclogin2
Pour plus d'informations sur l'inscription manuelle d'un SPN pour SQL Server, consultez Inscrire un nom de principal du service pour les connexions Kerberos.
[Haut de la page]
Tâches associées
Créer ou configurer un écouteur de groupe de disponibilité (SQL Server)
Afficher les propriétés d'écouteur de groupe de disponibilité (SQL Server)
Supprimer un écouteur de groupe de disponibilité (SQL Server)
Configurer l'accès en lecture seule sur un réplica de disponibilité (SQL Server)
Configurer le routage en lecture seule pour un groupe de disponibilité (SQL Server)
[Haut de la page]
Contenu connexe
Présentation de l'écouteur du groupe de disponibilité (blog de l'équipe SQL Server AlwaysOn)
Blog de l'équipe de SQL Server AlwaysOn : Blog officiel de l'équipe de SQL Server AlwaysOn
[Haut de la page]
Voir aussi
Concepts
Vue d'ensemble des groupes de disponibilité AlwaysOn (SQL Server)
Connectivité client AlwaysOn (SQL Server)
À propos de l'accès de la connexion client aux réplicas de disponibilité (SQL Server)
Secondaires actifs : réplicas secondaires lisibles (groupes de disponibilité d'AlwaysOn)
Connecter des clients à une session de mise en miroir de bases de données (SQL Server)