Qu’est-ce que le service Azure Private Link ?

Le service Azure Private Link est la référence à votre propre service Azure Private Link. L’accès Private Link peut être activé pour un service qui s’exécute derrière Azure Standard Load Balancer. De cette façon, les utilisateurs du service pourront y accéder à l’aide d’une connexion privée, à partir de leurs propres réseaux virtuels. Vos clients peuvent créer un point de terminaison privé dans leur réseau virtuel et le mapper dans ce service. Cet article explique les concepts qui sont utilisés côté fournisseur de services.

Diagram of Azure private link service.

Figure : Service Azure Private Link.

Workflow

Diagram of private link service workflow.

Figure : Workflow du service Azure Private Link.

  • Configurez votre application pour qu’elle s’exécute derrière un équilibreur de charge standard dans votre réseau virtuel. Si votre application est déjà configurée pour s’exécuter derrière un équilibreur de charge standard, vous pouvez ignorer cette étape.

  • Créez un service Private Link référençant l’équilibreur de charge ci-dessus. Durant le processus de sélection de l’équilibrage de charge, choisissez la configuration d’adresse IP front-end où vous souhaitez recevoir le trafic. Choisissez un sous-réseau pour les adresses IP NAT du service Private Link. Il est recommandé de disposer d’au moins 8 adresses IP NAT disponibles dans le sous-réseau. Pour le fournisseur de services, tout le trafic des utilisateurs semble provenir de ce pool d’adresses IP privées. Choisissez les propriétés et les paramètres nécessaires pour le service Private Link.

    Notes

    Le service Azure Private Link est uniquement pris en charge sur Standard Load Balancer.

Partager un service

Une fois que vous avez créé un service Private Link, Azure génère un moniker global unique appelé alias, basé sur le nom que vous avez fourni pour votre service. Vous pouvez partager l’alias ou l’URI de ressource de votre service avec vos clients hors connexion. Les utilisateurs peuvent démarrer une connexion Private Link à l’aide de l’alias ou de l’URI de ressource.

Gérer les demandes de connexion

Lorsque l’utilisateur démarre une connexion, le fournisseur de services peut accepter ou rejeter la demande de connexion. Toutes les demandes de connexion sont listées sous la propriété privateendpointconnections dans le service Private Link.

Supprimer le service

Si le service Private Link n’est plus utilisé, vous pouvez le supprimer. Toutefois, avant de le supprimer, vérifiez qu’il n’est associé à aucune connexion de point de terminaison privé. Vous pouvez rejeter toutes les connexions et supprimer le service.

Propriétés

Le service Private Link spécifie les propriétés suivantes :

Propriété Explication
État de provisionnement (provisioningState) Propriété en lecture seule qui liste l’état de provisionnement actuel du service Private Link. Les états de provisionnement applicables sont les suivants : Deleting, Failed,Succeeded,*Updating (Suppression, Échec, Réussite, Mise à jour). Lorsque l’état de provisionnement est Succeeded, cela signifie que votre service Private Link a bien été provisionné.
Alias (alias) L’alias est une chaîne globale unique en lecture seule qui représente votre service. Il vous permet de masquer les données client de votre service, et de créer un nom facile à partager pour votre service. Lorsque vous créez un service Private Link, Azure génère un alias pour ce service, que vous pouvez ensuite partager avec vos clients. Vos clients peuvent utiliser cet alias pour demander une connexion à votre service.
Visibilité (visibility) La propriété visibility permet de contrôler les paramètres d’exposition de votre service Private Link. Les fournisseurs de services peuvent choisir d’exposer leurs services aux abonnements disposant d’autorisations de contrôle d’accès en fonction du rôle Azure. Vous pouvez également restreindre le nombre d’abonnements pour limiter l’exposition.
Approbation automatique (autoApproval) L’approbation automatique permet de contrôler l’accès automatisé au service Private Link. Les abonnements qui figurent dans la liste d’approbation automatique sont approuvés automatiquement lorsqu’une connexion est demandée à partir des points de terminaison privés de ces abonnements.
Configuration de l’adresse IP front-end de l’équilibreur de charge (loadBalancerFrontendIpConfigurations) Le service Private Link est associé à l’adresse IP front-end d’un équilibreur de charge standard. Tout le trafic destiné au service atteindra le front-end de l’équilibreur de charge standard. Vous pouvez configurer des règles d’équilibreur de charge standard pour diriger ce trafic vers les pools back-end où sont exécutées vos applications. Les adresses IP front-end d’équilibreur de charge sont différentes des adresses IP NAT.
Configuration de l’adresse IP NAT (ipConfigurations) Cette propriété concerne la configuration de l’adresse IP NAT (traduction d’adresses réseau) du service Private Link. L’adresse IP NAT peut être choisie à partir de n’importe quel sous-réseau du réseau virtuel d’un fournisseur de services. Le service Private Link effectue la traduction d’adresses réseau (NAT) côté destination pour le trafic Private Link. Cette NAT évite tout conflit d’adresses IP entre l’espace d’adressage source (côté client) et l’espace d’adressage de destination (fournisseur de services). Du côté de la destination ou du fournisseur de services, l’adresse IP NAT s’affiche en tant qu’adresse IP source pour tous les paquets reçus par votre service. L’adresse IP de destination s’affiche pour tous les paquets envoyés par votre service.
Connexions de points de terminaison privés (privateEndpointConnections) Cette propriété liste les points de terminaison privés qui se connectent au service Private Link. Plusieurs points de terminaison privés peuvent se connecter au même service Private Link, et le fournisseur de services peut contrôler l’état de chaque point de terminaison privé.
Proxy TCP v2 (EnableProxyProtocol) Cette propriété permet au fournisseur de services d’utiliser le proxy TCP v2 pour récupérer les informations de connexion relatives au consommateur de services. Il appartient au fournisseur de services de définir les configurations du récepteur afin de pouvoir analyser l’en-tête du protocole de proxy v2.

Détails

  • Le service Private Link est accessible à partir des points de terminaison privés approuvés qui sont situés dans une région publique quelconque. Le point de terminaison privé est accessible à partir du même réseau virtuel et des mêmes réseaux virtuels appairés régionalement. Vous pouvez accéder à un point de terminaison privé à partir de réseaux virtuels appairés au niveau mondial, ainsi que localement, à l’aide de connexions privées VPN ou ExpressRoute.

  • Lors de la création d’un service Private Link, une interface réseau est créée pour le cycle de vie de la ressource. Cette interface ne peut pas être gérée par le client.

  • Le service Private Link doit être déployé dans la même région que le réseau virtuel et Standard Load Balancer.

  • Plusieurs points de terminaison privés appartenant à différents réseaux virtuels, abonnements et/ou locataires Active Directory peuvent accéder à un même service Private Link. La connexion est établie via un workflow de connexion.

  • Vous pouvez créer plusieurs services Private Link sur une même instance de Standard Load Balancer à l’aide de différentes configurations d’adresses IP front-end. Le nombre de services Private Link qu’il est possible de créer dans chaque instance Standard Load Balancer et dans chaque abonnement est limité. Pour plus d’informations, consultez limites Azure.

  • Le service Private Link peut être associé à plusieurs configurations d’adresses IP NAT. Le fait de choisir plusieurs configurations d’adresses IP NAT peut permettre aux fournisseurs de services d’effectuer une mise à l’échelle. Aujourd’hui, les fournisseurs de services peuvent attribuer jusqu’à 8 adresses IP NAT à chaque service Private Link. Avec chaque adresse IP NAT, vous pouvez affecter davantage de ports pour vos connexions TCP et, donc, effectuer un scale-out. Une fois que vous avez ajouté des adresses IP NAT à un service Private Link, vous ne pouvez pas supprimer ces adresses. Cette restriction a été mise en place dans le but d’empêcher que les connexions actives ne soient impactées par la suppression d’adresses IP NAT.

Alias

Un alias est un nom global unique correspondant à votre service. Il vous permet de masquer les données client de votre service, et de créer un nom facile à partager pour votre service. Lorsque vous créez un service Private Link, Azure génère un alias pour ce service, que vous pouvez ensuite partager avec vos clients. Vos clients peuvent utiliser cet alias pour demander une connexion à votre service.

L’alias se compose de trois parties : Préfixe.GUID.Suffixe

  • Le préfixe correspond au nom du service. Vous pouvez choisir votre propre préfixe. Une fois que « Alias » est créé, vous ne pouvez pas le modifier : choisissez donc votre préfixe de façon appropriée.

  • Le GUID sera fourni par la plateforme. Ce GUID rend le nom globalement unique.

  • Le suffixe est ajouté par Azure : région.azure.privatelinkservice

Alias complet : Préfixe. {GUID}.région.azure.privatelinkservice

Contrôler l’exposition du service

Le service Private Link fournit trois options dans le paramètre Visibilité pour contrôler l’exposition de votre service. Le paramètre de visibilité détermine si un contrôle serveur consommateur peut se connecter à votre service. Voici les options du paramètre de visibilité, du plus restrictif au moins restrictif :

  • Contrôle d’accès en fonction du rôle uniquement : si votre service est destiné à une consommation privée à partir de différents réseaux virtuels dont vous êtes propriétaire, vous pouvez utiliser le contrôle d’accès en fonction du rôle dans les abonnements qui sont associés à un même locataire Active Directory. La visibilité entre les locataires est autorisée via le contrôle d’accès en fonction du rôle.

  • Limité par abonnement : si votre service est consommé par différents abonnés, vous pouvez limiter l’exposition à un ensemble limité d’abonnements auxquels vous faites confiance. Les autorisations peuvent être pré-approuvées.

  • Toute personne avec votre alias : si vous souhaitez rendre votre service public et autoriser quiconque avec votre alias du service Private Link à demander une connexion, sélectionnez cette option.

Contrôler l’accès au service

Les consommateurs qui ont accès à votre service Private Link (par le biais du paramètre de visibilité) peuvent créer un point de terminaison privé dans leurs réseaux virtuels et demander à se connecter à votre service Private Link. La connexion de point de terminaison privé sera créée à l’état Pending (En attente) dans l’objet du service Private Link. Le fournisseur de services est chargé d’approuver, rejeter ou supprimer la demande de connexion. Vous pouvez approuver, rejeter ou supprimer la connexion. Seules les connexions approuvées peuvent envoyer du trafic vers le service Private Link.

L’approbation des connexions peut être automatisée à l’aide de la propriété d’approbation automatique du service Private Link. L’approbation automatique permet aux fournisseurs de services de préapprouver un groupe d’abonnements pour leur permettre d’accéder automatiquement à leur service. Les clients devront partager leurs abonnements hors connexion pour que les fournisseurs de services puissent les ajouter à la liste d’approbation automatique. L’approbation automatique est un sous-ensemble du tableau de visibilité.

La propriété de visibilité permet de contrôler l’exposition de votre service, tandis que la propriété d’approbation automatique permet de contrôler les paramètres d’approbation de votre service. Si un client demande à se connecter à partir d’un abonnement figurant dans la liste d’approbation automatique, la connexion est automatiquement approuvée puis établie. Les fournisseurs de services n’ont pas besoin d’approuver manuellement les demandes. Si un client demande à se connecter à partir d’un abonnement du tableau de visibilité et non du tableau d’approbation automatique, la demande sera reçue par le fournisseur de services. Le fournisseur de services doit approuver manuellement les connexions.

Obtention d’informations de connexion à l’aide du proxy TCP v2

Dans le service Private Link, l’adresse IP source des paquets provenant du point de terminaison privé est traduite en adresse réseau (NAT) côté fournisseur de services à l’aide de l’adresse IP NAT allouée à partir du réseau virtuel du fournisseur. Les applications reçoivent l’adresse IP NAT allouée au lieu de l’adresse IP source réelle des consommateurs de services. Si votre application a besoin d’une adresse IP source réelle du côté du consommateur, vous pouvez activer le protocole proxy sur votre service et récupérer les informations de l’en-tête du protocole proxy. En plus de l’adresse IP source, l’en-tête du protocole proxy comporte l’ID de lien du point de terminaison privé. La combinaison de l’adresse IP source et de l’ID de lien peut aider les fournisseurs de services à identifier leurs consommateurs de manière unique.

Pour plus d’informations sur le protocole de proxy, voir ici.

Ces informations sont encodées à l’aide d’un vecteur TLV (Type-Length-Value) personnalisé comme suit :

Détails TLV personnalisés :

Champ Longueur (octets) Description
Type 1 PP2_TYPE_AZURE (0xEE)
Longueur 2 Longueur de la valeur
Valeur 1 PP2_SUBTYPE_AZURE_PRIVATEENDPOINT_LINKID (0x01)
4 UINT32 (4 octets) représentant l’ID de lien du point de terminaison privé. Encodé au format Little Endian.

Notes

Le fournisseur de service est chargé de s’assurer que le service situé derrière l’équilibreur de charge standard est configuré pour analyser l’en-tête du protocole de proxy, conformément à la spécification, lorsque le protocole est activé dans un service Private Link. La demande échoue si le paramètre de protocole de proxy est activé dans un service Private Link, mais que le service du fournisseur de services n’est pas configuré pour analyser l’en-tête. La demande échouera si le service du fournisseur de services attend un en-tête de protocole de proxy alors que le paramètre n’est pas activé dans le service Private Link. Une fois le paramètre de protocole de proxy activé, l’en-tête de protocole de proxy est également inclus dans les sondes d’intégrité HTTP/TCP, de l’hôte vers les machines virtuelles back-end. Les informations client ne sont pas contenues dans l’en-tête.

Le LINKID correspondant qui fait partie du protocole PROXYv2 (TLV) se trouve sur PrivateEndpointConnection comme propriété linkIdentifier.

Pour plus d’informations, consultez API Private Link Services.

Limites

Voici les limitations connues lors de l’utilisation du service Private Link :

  • Il est pris en charge uniquement sur Standard Load Balancer. Il n’est pas pris en charge sur Basic Load Balancer.

  • Pris en charge uniquement sur Standard Load Balancer où le pool principal est configuré par la carte réseau. Non pris en charge sur Standard Load Balancer où le pool principal est configuré par adresse IP.

  • Il prend en charge uniquement le trafic IPv4.

  • Il prend en charge uniquement le trafic TCP et le trafic UDP.

  • Private Link Service dispose d’un délai d’inactivité d’environ 5 minutes (300 secondes). Pour éviter d’atteindre cette limite, les applications qui se connectent via le service Private Link doivent utiliser moins de KeepAlives TCP qu’à cette période.

  • Pour qu’une règle NAT de trafic entrant ayant pour type défini pool principal fonctionne avec le service Azure Private Link, une règle d’équilibrage de charge doit être configurée.

Étapes suivantes