Cette page explique comment les équilibreurs de charge réseau passthrough externes distribuent le trafic.
Sélection du backend et suivi des connexions
La sélection du backend et le suivi des connexions fonctionnent ensemble pour équilibrer plusieurs connexions sur différents backends et pour acheminer tous les paquets de chaque connexion vers le même backend. Pour ce faire, vous devez adopter une stratégie en deux parties. Tout d'abord, un backend est sélectionné à l'aide d'un hachage cohérent. Cette sélection est ensuite enregistrée dans un tableau de suivi des connexions.
Les étapes suivantes décrivent la sélection du backend et le suivi des connexions.
1. Rechercher une entrée dans la table de suivi des connexions
L'équilibreur de charge détermine si un paquet à équilibrage de charge appartient à une nouvelle connexion ou à une connexion existante en suivant le processus suivant :
Paquet TCP avec l'indicateur
SYN:Si le mode de suivi des connexions de l'équilibreur de charge est
PER_CONNECTION, passez à l'étape Identifier les backends éligibles. En mode de suiviPER_CONNECTION, un paquet TCP avec l'indicateurSYNreprésente toujours une nouvelle connexion, quelle que soit l'affinité de session configurée.Si le mode de suivi des connexions de l'équilibreur de charge est défini sur
PER_SESSIONet que l'affinité de session est définie surNONEouCLIENT_IP_PORT_PROTO, passez à l'étape Identifier les backends éligibles. En mode de suiviPER_SESSION, un paquet TCP avec l'indicateurSYNreprésente une nouvelle connexion uniquement lorsque l'une des options d'affinité de session à cinq tuples (NONEouCLIENT_IP_PORT_PROTO) est utilisée.
- Le suivi des connexions n'est pas compatible : si l'affinité de session configurée n'est pas compatible avec le suivi des connexions pour le protocole du paquet, passez à l'étape Identifier les backends éligibles. Pour savoir quels protocoles peuvent être suivis, consultez le tableau de la section Mode de suivi des connexions.
Tous les autres paquets : l'équilibreur de charge vérifie si le paquet correspond à une entrée existante dans la table de suivi des connexions. La précision du hachage de paquet utilisé pour vérifier s'il existe une entrée dans la table de suivi des connexions dépend du mode de suivi des connexions et de l'affinité de session que vous avez configurés. Pour en savoir plus, consultez le tableau de la section Mode de suivi des connexions.
Si le paquet correspond à une entrée de la table de suivi des connexions, l'équilibreur de charge l'envoie au backend précédemment sélectionné.
Si le paquet ne correspond pas à une entrée de la table de suivi des connexions, passez à l'étape Identifier les backends éligibles.
Pour savoir combien de temps une entrée de tableau de suivi des connexions persiste et dans quelles conditions, consultez l'étape Gérer les entrées du tableau de suivi des connexions.
2. Étapes de sélection du backend
Pour une nouvelle connexion, l'équilibreur de charge utilise le hachage cohérent pour sélectionner un backend parmi les backends éligibles.
Les étapes suivantes décrivent le processus de sélection d'un backend éligible pour une nouvelle connexion, puis l'enregistrement de cette connexion dans un tableau de suivi des connexions.
2.1 Identifier les backends éligibles
Les backends éligibles sont les backends qui peuvent recevoir de nouvelles connexions. Le tableau suivant définit l'ensemble des backends éligibles selon que vous avez configuré une stratégie de basculement et que l'équilibrage de charge pondéré est activé ou non.
| Stratégie de basculement | Équilibrage de charge pondéré | Backends éligibles |
|---|---|---|
Lorsqu'aucune règle de basculement n'est configurée et que l'équilibrage de charge pondéré est désactivé, tous les backends configurés sont des backends principaux. L'ensemble des backends éligibles est défini comme suit :
|
||
Lorsqu'aucune règle de basculement n'est configurée et que l'équilibrage de charge pondéré est activé, les backends éligibles sont ceux qui proviennent du premier des ensembles suivants qui n'est pas vide :
|
||
Lorsqu'une règle de basculement est configurée et que l'équilibrage de charge pondéré est désactivé, l'équilibreur de charge utilise les informations de vérification de l'état l'état et la configuration de la règle de basculement pour définir l'ensemble des backends éligibles :
|
||
Lorsqu'une stratégie de basculement est configurée et que l'équilibrage de charge pondéré est activé, l'équilibreur de charge utilise les informations sur la pondération, les informations vérification de l'état'état et la configuration de la stratégie de basculement pour définir l'ensemble des backends éligibles :
|
2.2 Sélectionnez un backend éligible
L'équilibreur de charge conserve les hachages des backends éligibles, chaque hachage de backend étant mappé à un cercle unité. L'équilibrage de charge pondéré modifie la façon dont les backends éligibles sont mappés au cercle, de sorte que les backends ayant des pondérations plus élevées sont plus susceptibles d'être sélectionnés, proportionnellement à leurs pondérations.
Lors du traitement d'un paquet pour une connexion qui ne figure pas dans la table de suivi des connexions, l'équilibreur de charge calcule un hachage des caractéristiques du paquet et mappe ce hachage au même cercle unité, en sélectionnant un backend éligible sur la circonférence du cercle. L'ensemble des caractéristiques des paquets utilisées pour calculer le hachage des paquets est défini par le paramètre d'affinité de session. Par exemple, lorsque l'affinité de session sélectionnée génère un hachage de sélection de backend à deux ou trois tuples, toutes les connexions TCP provenant d'une adresse IP source sont mappées sur le même backend éligible.
- Si aucune affinité de session n'est explicitement configurée, l'affinité de session
NONEest définie par défaut.
Le hachage cohérent garantit que l'équilibreur de charge attribue les nouvelles connexions aux backends éligibles de manière à minimiser les perturbations de mappage, même si le nombre de backends éligibles ou leurs pondérations changent.
L'équilibreur de charge sélectionne toujours le même backend éligible pour une connexion et, plus généralement, toujours le même backend éligible pour tous les paquets présentant des caractéristiques identiques, telles que définies par le paramètre d'affinité de session, dans les situations suivantes :
Si l'équilibrage de charge pondéré n'est pas configuré, l'ensemble des backends éligibles ne change pas.
Si l'équilibrage de charge pondéré est configuré, lorsque l'ensemble des backends éligibles ne change pas et que la pondération de chaque backend éligible reste constante.
Si un backend éligible est ajouté, supprimé ou si son poids est modifié, le hachage cohérent vise à minimiser la perturbation des mappages vers les autres backends éligibles. En d'autres termes, la plupart des connexions qui sont mappées vers d'autres backends éligibles continuent de l'être vers le même backend éligible.
De plus, le hachage cohérent garantit que l'équilibreur de charge répartit les nouvelles connexions entre les backends éligibles de la manière la plus équitable possible. Pour tous les hachages de paquets possibles, tels que définis par le paramètre d'affinité de session configuré (et plus précisément, pour toutes les connexions possibles lorsque l'affinité de session génère un hachage à cinq tuples pour la sélection du backend) :
Si l'équilibrage de charge pondéré n'est pas configuré, environ
1/Nhachages de paquets possibles sont mappés à chaque backend éligible, oùNcorrespond au nombre de backends éligibles.Si l'équilibrage de charge pondéré est configuré, le ratio de hachages de paquets possibles qui correspondent à chaque backend éligible est approximativement égal à la pondération d'un backend éligible divisée par la somme de toutes les pondérations de backend éligibles.
Les deux exemples suivants montrent comment l'équilibrage de charge pondéré affecte les probabilités de sélection de chaque backend éligible :
Si le service de backend comporte deux backends éligibles (le premier avec un poids de
1et le second avec un poids de4), le premier backend éligible a une probabilité de sélection de 20 % (1÷(1+4)) et le second backend éligible a une probabilité de sélection de 80 % (4÷(1+4)).Si le service de backend comporte trois backends éligibles (backend éligible
aavec un poids de0, backend éligiblebavec un poids de2et backend éligiblecavec un poids de6), le backendaa une probabilité de sélection de 0 % (0/(0+2+6)), le backendba une probabilité de sélection de 25 % (2/(0+2+6)) et le backendca une probabilité de sélection de 75 % (6/(0+2+6)).
2.3 Créer une entrée dans le tableau de suivi des connexions
Après avoir sélectionné un backend, l'équilibreur de charge crée une entrée dans la table de suivi des connexions si l'affinité de session configurée est compatible avec le suivi des connexions pour le protocole du paquet.Si l'affinité de session configurée n'est pas compatible avec le suivi des connexions pour le protocole du paquet, ignorez cette étape.
Si l'affinité de session configurée est compatible avec le suivi des connexions pour le protocole du paquet, l'entrée de la table de suivi des connexions qui est créée mappe les caractéristiques du paquet au backend sélectionné. Les champs d'en-tête de paquet utilisés pour ce mappage dépendent du mode de suivi des connexions et de l'affinité de session que vous avez configurés.
Pour savoir quels protocoles peuvent être suivis en fonction de vos choix de configuration et quelles caractéristiques de paquets sont utilisées pour le hachage dans le tableau de suivi des connexions, consultez le tableau de la section Mode de suivi des connexions.
3. Gérer les entrées de la table de suivi des connexions
L'équilibreur de charge gère les entrées de la table de suivi des connexions en fonction des événements et des règles suivants :
- Les entrées inactives sont supprimées : une entrée de la table de suivi des connexions est supprimée après 60 secondes d'inactivité de la connexion. Pour en savoir plus, consultez Délai d'inactivité.
Connexions TCP fermées : les entrées de la table de suivi des connexions pour les connexions TCP ne sont pas supprimées lorsqu'une connexion TCP est fermée avec un paquet
FINouRST. Il est possible qu'elle soit supprimée ultérieurement en tant qu'entrée inactive. Chaque nouvelle connexion TCP comporte toujours l'indicateurSYNet est soumise au traitement décrit à l'étape Vérifier l'existence d'une entrée dans la table de suivi des connexions.Drainage de connexion lors du basculement : lorsqu'au moins un backend de basculement est configuré et que le paramètre de drainage de connexion lors du basculement est désactivé, l'équilibreur de charge supprime toutes les entrées de la table de suivi des connexions lorsque l'ensemble des backends éligibles bascule entre les backends principaux et de basculement. Pour en savoir plus, consultez Drainage de connexion en cas de basculement.
Persistance des connexions sur les backends non opérationnels : les entrées de la table de suivi des connexions peuvent être supprimées si un backend devient non opérationnel. Ce comportement dépend des facteurs décrits dans Persistance des connexions sur les backends non opérationnels.
Lorsqu'une entrée de table de suivi des connexions est supprimée, car un backend précédemment sélectionné passe de l'état opérationnel à l'état non opérationnel, les paquets suivants pour la connexion sont traités comme s'ils appartenaient à une nouvelle connexion. Après avoir sélectionné un nouveau backend éligible pour les paquets suivants, l'équilibreur de charge crée une entrée de remplacement dans la table de suivi des connexions.
Une entrée de table de suivi des connexions de remplacement se comporte exactement comme n'importe quelle autre entrée de table de suivi des connexions et est soumise aux événements et aux règles de cette étape.
Si le backend précédemment sélectionné redevient opérationnel après avoir été non opérationnel, la modification de la vérification de l'état seule n'entraîne pas la suppression de l'entrée de la table de suivi des connexions de remplacement. Une exception se produit lorsqu'au moins un backend de secours est configuré et que le paramètre "Drainage de connexion lors du basculement" est désactivé. Si le changement d'état du vérification de l'état de l'état d'un backend précédemment sélectionné coïncide avec l'ensemble des backends éligibles passant des backends principaux aux backends de secours, les entrées de la table de suivi des connexions sont supprimées.
Drainage de connexion pour les backends supprimés, arrêtés ou supprimés : si le drainage de connexion pour les backends supprimés, arrêtés ou supprimés est activé, les entrées du tableau de suivi des connexions sont supprimées après un délai de drainage de connexion configurable. Le compte à rebours du délai d'inactivité commence lorsque la commande de suppression, d'arrêt ou de suppression d'un backend est reçue. Si le drainage de connexion pour les backends supprimés, arrêtés ou supprimés est désactivé, les entrées de la table de suivi des connexions sont supprimées lorsque la commande de suppression, d'arrêt ou de suppression d'un backend est reçue. Pour en savoir plus, consultez Activer le drainage de connexion.
Affinité de session
Le paramètre d'affinité de session d'un équilibreur de charge réseau passthrough externe définit le hachage de paquet pour la sélection du backend et, en fonction du mode de suivi des connexions, le hachage de paquet pour le suivi des connexions.
Vous configurez l'affinité de session sur le service de backend, et non sur chaque groupe d'instances ou NEG de backend. L'affinité de session détermine les en-têtes IP et de couche 4 utilisés pour calculer un hachage des caractéristiques des paquets. Le hachage des caractéristiques des paquets est utilisé dans les étapes de sélection du backend.
Les équilibreurs de charge réseau passthrough externes sont compatibles avec les paramètres d'affinité de session suivants.
| Méthode de hachage pour la sélection du backend | Paramètre d'affinité de session |
|---|---|
|
Hachage à cinq tuples (adresse IP source, port source, protocole, adresse IP de destination et port de destination) pour les paquets non fragmentés incluant des informations de port (paquets TCP et paquets UDP non fragmentés) OUHachage à trois tuples (composé de l'adresse IP source, de l'adresse IP de destination et du protocole) pour les paquets UDP fragmentés et les paquets de tous les autres protocoles |
NONE1
OU CLIENT_IP_PORT_PROTO
|
| Hachage à trois tuples (composé de l'adresse IP source, de l'adresse IP de destination et du protocole) |
CLIENT_IP_PROTO |
| Hachage à deux tuples (composé de l'adresse IP source et de l'adresse IP de destination) |
CLIENT_IP |
1 : l'affinité de session NONE n'indique pas qu'il n'y a pas d'affinité de session. Cela signifie que l'affinité de session est effectuée avec un hachage à cinq tuples ou à trois tuples des caractéristiques des paquets, ce qui est fonctionnellement identique au comportement lorsque CLIENT_IP_PORT_PROTO est défini.
Règle de suivi de connexion
Cette section décrit les paramètres de la règle de suivi des connexions de l'équilibreur de charge :
- Mode de suivi des connexions
- Persistance des connexions sur les backends non opérationnels
- Délai d'inactivité
Mode de suivi des connexions
Cette section décrit quand et comment l'équilibreur de charge crée des entrées dans sa table de suivi des connexions. Les équilibreurs de charge réseau passthrough externes sont compatibles avec le suivi des connexions en fonction du protocole et de l'affinité de session :Les connexions TCP sont toujours suivies, pour toutes les options d'affinité de session.
Les connexions UDP, ESP et GRE peuvent être suivies pour toutes les options d'affinité de session sauf
NONE.Tous les autres protocoles, tels qu'ICMP et ICMPv6, ne peuvent pas faire l'objet d'un suivi des connexions.
Lorsque le suivi des connexions est possible, le mode de suivi des connexions, le protocole et l'affinité de session déterminent l'ensemble des caractéristiques des paquets qui sont utilisées pour créer le hachage des paquets dans chaque entrée de la table de suivi des connexions.
Le mode de suivi des connexions peut être l'un des suivants :
PER_CONNECTION: il s'agit du mode de suivi des connexions par défaut, qui est aussi le plus précis. Chaque connexion est définie comme un hachage à cinq tuples ou un hachage à trois tuples des caractéristiques des paquets, selon que les informations sur les ports sont présentes ou non dans le paquet. Les paquets non fragmentés qui incluent des informations de port (tels que les paquets TCP et les paquets UDP non fragmentés) sont suivis avec des hachages à cinq tuples. Tous les autres paquets sont suivis avec des hachages à trois tuples.PER_SESSION: ce mode de suivi des connexions moins précis utilise un hachage qui correspond au hachage de l'affinité de session. En fonction de l'affinité de session choisie, le mode de suiviPER_SESSIONpeut traiter plusieurs connexions distinctes comme une seule connexion à des fins de suivi des connexions. Cela réduit la fréquence à laquelle une connexion est considérée comme nouvelle et soumise aux étapes de sélection du backend.
Le tableau suivant récapitule les informations :
- Les hachages de paquets utilisés pour la sélection du backend
- Hachages de paquets utilisés pour le suivi des connexions, en fonction du mode de suivi des connexions, du protocole et de l'affinité de session.
| Affinité de session | Hachage de paquets pour la sélection du backend | Hachage des paquets pour le suivi des connexions | |
|---|---|---|---|
Lorsque vous utilisez le mode de suivi PER_CONNECTION (par défaut) |
Lorsque vous utilisez le mode de suivi PER_SESSION |
||
NONE (par défaut) |
|
|
|
CLIENT_IP_PORT_PROTO |
|
|
|
CLIENT_IP_PROTO |
|
|
|
CLIENT_IP |
|
|
|
Pour savoir comment modifier le mode de suivi des connexions, consultez la page Configurer une règle de suivi des connexions.
Persistance des connexions sur les backends non opérationnels
L'option Persistance des connexions sur les backends non opérationnels permet de déterminer si les connexions existantes persistent sur une VM de backend ou un point de terminaison précédemment sélectionnés après que le backend n'est plus opérationnel, à condition que le backend reste dans un groupe d'instances ou un NEG à équilibrage de charge.
Les options de persistance de connexion suivantes sont disponibles :
DEFAULT_FOR_PROTOCOL(par défaut)NEVER_PERSISTALWAYS_PERSIST
Le tableau suivant récapitule si les connexions persistent en fonction des backends non opérationnels, selon l'option de persistance des connexions, l'affinité de session, le mode de suivi des connexions et le protocole.
| Persistance de connexion sur les backends non opérationnels | Comportement de la persistance des connexions sur les backends non opérationnels | |
|---|---|---|
Lorsque vous utilisez le mode de suivi PER_CONNECTION (par défaut) |
Lorsque vous utilisez le mode de suivi PER_SESSION |
|
DEFAULT_FOR_PROTOCOL |
|
|
NEVER_PERSIST |
Tous les protocoles : les connexions ne persistent jamais sur les backends non opérationnels. | |
ALWAYS_PERSIST
N'utilisez cette option que pour les cas d'utilisation avancée. |
|
Configuration impossible |
Lorsque la persistance des connexions sur les backends non opérationnels s'applique au trafic, chaque connexion persiste tant qu'une entrée de table de suivi des connexions correspondante existe. Pour en savoir plus, consultez l'étape Gérer les entrées du tableau de suivi des connexions.
Pour savoir comment modifier le comportement de la persistance des connexions, consultez la page Configurer une règle de suivi des connexions.
Comportement de la persistance de connexion TCP sur les backends non opérationnels
L'équilibreur de charge utilise le suivi de connexion par hachage à cinq tuples pour les connexions TCP dans les situations suivantes :
- Lorsque vous utilisez le mode de suivi
PER_CONNECTION(toutes les affinités de session) - Lorsque vous utilisez le mode de suivi
PER_SESSION, et l'affinité de session est soitNONE, soitCLIENT_IP_PORT_PROTO.
Lorsque l'équilibreur de charge utilise un suivi de connexion par hachage à cinq tuples pour les connexions TCP, gardez à l'esprit les comportements suivants :
- Si le backend non opérationnel continue de répondre aux paquets, la connexion se poursuit jusqu'à ce qu'elle soit réinitialisée ou fermée (par le backend non opérationnel ou le client).
- Si le backend non opérationnel envoie un paquet de réinitialisation TCP (RST) ou ne répond pas aux paquets, le client peut effectuer une nouvelle tentative de connexion, laissant ainsi l'équilibreur de charge sélectionner un autre backend éligible. (Les paquets TCP
SYNsont traités comme de nouvelles connexions lors de l'étape Identifier les backends éligibles.)
Délai d'inactivité
Les entrées des tables de suivi des connexions expirent 60 secondes après que l'équilibreur de charge a traité le dernier paquet correspondant à l'entrée. Cette valeur de délai d'inactivité ne peut pas être modifiée.Drainage de connexion pour les backends supprimés, arrêtés ou effacés
Le drainage de connexion fournit une durée minimale configurable pendant laquelle les connexions existantes peuvent persister dans la table de suivi des connexions de l'équilibreur de charge lorsque l'un des événements suivants se produit :
- Une instance de machine virtuelle (VM) est supprimée d'un groupe d'instances de backend (y compris l'abandon d'une instance dans un groupe d'instances géré de backend)
- Une VM est arrêtée ou supprimée (y compris les actions automatiques telles que les mises à jour progressives ou la réduction de la taille d'un groupe d'instances géré de backend).
- Un point de terminaison est supprimé d'un groupe de points de terminaison du réseau (NEG) de backend.
Par défaut, le drainage de connexion lorsque les backends sont supprimés, arrêtés ou effacés est désactivé. Pour en savoir plus, consultez Activer le drainage de connexion.
Équilibrage de charge pondéré
L'équilibrage de charge pondéré influence les backends éligibles dans les étapes de sélection du backend. Chaque VM ou point de terminaison de backend indique sa pondération à l'équilibreur de charge à l'aide d'une vérification d'état HTTP et d'un en-tête de réponse personnalisé. Pour utiliser l'équilibrage de charge pondéré, vous devez configurer les éléments suivants sur le service de backend de l'équilibreur de charge :
- La règle de localité (
localityLbPolicy) doit être définie surWEIGHTED_MAGLEV. La vérification de l'état doit être une vérification de l'état de l'état HTTP qui envoie un en-tête de réponse spécial :
- Le nom du champ de l'en-tête de réponse doit être
X-Load-Balancing-Endpoint-Weight. - Les valeurs des champs de l'en-tête de réponse peuvent être comprises entre
0et1000(inclus).
- Le nom du champ de l'en-tête de réponse doit être
Pour en savoir plus, consultez Configurer l'équilibrage de charge pondéré.
Points à prendre en compte pour l'équilibrage de charge pondéré
L'équilibrage de charge pondéré est utile dans les scénarios suivants, qui permettent à un backend de continuer à traiter ses connexions existantes :
L'équilibrage de charge pondéré permet à un backend qui traite des connexions de longue durée ou des connexions impliquant de grandes quantités de données d'indiquer à l'équilibreur de charge de réduire le nombre de nouvelles connexions qu'il reçoit.
L'équilibrage de charge pondéré permet à un backend surchargé ou en cours de maintenance de se retirer des backends éligibles aux nouvelles connexions. Pour ce faire, le backend surchargé envoie l'en-tête de réponse
X-Load-Balancing-Endpoint-Weight: 0(et peut continuer à réussir ou à échouer la vérification de l'état'équilibreur de charge). Cela fonctionne, car tous les backends avec un poids non nul (quel que soit l'état de la vérification de l'état'état) sont des backends éligibles préférables à l'étape Identifier les backends éligibles.
Tenez compte des points suivants lorsque vous utilisez l'équilibrage de charge :
Si les backends éligibles modifient fréquemment leurs pondérations, l'équilibrage de charge pondéré peut nuire à l'affinité de session. Pour en savoir plus, consultez l'étape Sélectionner un backend éligible.
Si vous utilisez le même groupe d'instances ou NEG comme backend de deux services de backend d'équilibreur de charge ou plus, vous pouvez indiquer un poids unique pour chaque service de backend en utilisant la stratégie suivante :
Utilisez une vérification de l'état HTTP unique pour chaque service de backend. Chaque vérification de l'état peut utiliser un paramètre
request-pathou un port de destination unique.Configurez les instances ou les points de terminaison backend pour qu'ils répondent avec les informations de pondération appropriées pour chaque vérification de l'état'état.
Basculement
Le basculement vous permet d'influencer l'ensemble des backends éligibles pour les nouvelles connexions en classant chaque groupe d'instances de backend ou NEG comme principal ou de basculement.
Par défaut, lorsque vous ajoutez un groupe d'instances ou un NEG à un service de backend, les VM ou points de terminaison membres sont des backends principaux, et le groupe d'instances ou le NEG est un groupe de backends principaux. Le basculement vous permet d'ajouter un groupe de backends de basculement (groupe d'instances ou NEG) dont les VM ou points de terminaison membres sont des backends de basculement :
- Pour le basculement, un service de backend doit comporter au moins un groupe de backend principal et au moins un groupe de backend de secours.
- Vous pouvez ajouter jusqu'à 50 groupes de backend principaux et 50 groupes de backend de basculement à un service de backend.
Avec le basculement, les facteurs suivants déterminent l'ensemble des backends éligibles :
- État de fonctionnement de chaque backend
- Le taux de basculement que vous avez configuré
- Paramètre Supprimer le trafic si les backends ne sont pas opérationnels
- Que vous utilisiez le basculement seul ou avec l'équilibrage de charge pondéré
Stratégie de basculement
Lorsqu'un service de backend comporte au moins un groupe de backend principal et au moins un groupe de backend de secours, vous pouvez ajuster les paramètres suivants dans sa stratégie de basculement :
- Taux de basculement : nombre compris entre
0.0et1.0, inclus. - Abandonner le trafic si les backends ne sont pas opérationnels : valeur booléenne qui détermine le comportement de dernier recours de l'équilibreur de charge. Le taux de basculement et le paramètre Supprimer le trafic si les backends sont non opérationnels fonctionnent avec d'autres facteurs pour contrôler l'ensemble des backends éligibles.
- Drainage de connexion en cas de basculement : valeur booléenne qui indique si les connexions persistent sur les backends précédemment sélectionnés lorsque l'ensemble des backends éligibles bascule entre les backends principaux et de secours.
Taux de basculement
Le ratio de basculement configuré détermine quand l'ensemble des backends éligibles bascule entre les backends principaux et de basculement. Le taux peut être un nombre compris entre 0.0 et 1.0 (inclus). Si vous n'indiquez pas de taux de basculement, Google Cloud utilise une valeur par défaut de 0.0. Nous vous recommandons de définir votre taux de basculement en vous servant d'un nombre qui fonctionne pour votre cas d'utilisation plutôt que d'utiliser cette valeur par défaut.
Drainage de connexion en basculement
L'option Drainage de connexion lors du basculement contrôle si une connexion existante persiste sur une VM de backend ou un point de terminaison précédemment sélectionnés lorsque l'ensemble des backends éligibles bascule entre les backends principaux et de secours.
Le drainage de connexion en cas de basculement est activé par défaut. Le tableau suivant récapitule la persistance des connexions en fonction de l'option de drainage de connexion en cas de basculement et du protocole :
| Option de drainage de connexion en cas de basculement | Comportement lorsque l'ensemble des backends éligibles bascule entre les backends principaux et de basculement |
|---|---|
| Activés (par défaut) |
Pour savoir quels protocoles peuvent être suivis, consultez le tableau de la section Mode de suivi des connexions. |
| Désactivé | Tous les protocoles : les connexions ne persistent pas lorsque l'ensemble des backends éligibles bascule entre les backends principaux et de basculement. |
La désactivation du drainage de connexion lors du basculement et de la restauration est utile dans les situations suivantes :
Application de correctifs sur les VM de backend : Avant l'application de correctifs, vous pouvez configurer les backends principaux opérationnels avec un poids non nul pour qu'ils échouent aux vérifications d'état, ou vous pouvez définir leur poids sur zéro. Ainsi, les backends éligibles peuvent être des backends de basculement opérationnels avec un poids non nul. En désactivant le drainage de connexion lors du basculement et de la restauration, l'équilibreur de charge supprime les entrées de la table de suivi des connexions, applique les étapes de sélection du backend aux paquets suivants et les envoie à un autre backend éligible. Le backend différent ferme ensuite la connexion avec une réinitialisation TCP, afin que les VM clientes puissent établir rapidement une nouvelle connexion à l'équilibreur de charge.
Nécessité de n'utiliser qu'une seule VM de backend pour garantir la cohérence des données : Si vous devez vous assurer que l'ensemble des backends éligibles ne comporte pas plus d'une VM ou d'un point de terminaison membre, la désactivation du drainage de connexion en cas de basculement et de rétablissement réduit le risque d'incohérences de données.
Pour savoir comment désactiver le drainage de connexion lors du basculement et de la restauration, consultez Désactiver le drainage de connexion lors du basculement et de la restauration.
Bonnes pratiques et conseils
Vous pouvez optimiser l'équilibreur de charge réseau passthrough externe en suivant ces consignes opérationnelles. Les sections suivantes fournissent les exigences techniques pour gérer les paquets UDP fragmentés et les bonnes pratiques pour tester la répartition de la charge à partir d'un seul client.
Gestion de la fragmentation UDP
Les équilibreurs de charge réseau passthrough externes basés sur un service de backend peuvent traiter à la fois les paquets UDP fragmentés et non fragmentés. Si votre application utilise des paquets UDP fragmentés, gardez à l'esprit les points suivants :
- Les paquets UDP peuvent être fragmentés avant d'atteindre un réseau VPC Google Cloud.
- Google Cloud Les réseaux VPC transfèrent les fragments UDP dès leur arrivée (sans attendre que tous les fragments arrivent).
- Les réseaux non-Google Cloud et l'équipement réseau sur site peuvent transférer les fragments UDP à leur arrivée, retarder les paquets UDP fragmentés jusqu'à ce que tous les fragments soient arrivés, ou supprimer les paquets UDP fragmentés. Pour en savoir plus, consultez la documentation du fournisseur réseau ou de l'équipement réseau.
Si vous prévoyez des paquets UDP fragmentés et que vous devez les acheminer vers les mêmes backends, utilisez la règle de transfert et les paramètres de configuration de service de backend suivants :
Configuration de la règle de transfert : N'utilisez qu'une seule règle de transfert
UDPouL3_DEFAULTpar adresse IP à équilibrage de charge, puis configurez la règle de transfert de façon à accepter le trafic sur tous les ports. Les fragments arriveront ainsi à la même règle de transfert. Même si les paquets fragmentés (autres que le premier fragment) ne disposent pas de port de destination, la configuration de la règle de transfert lui permettant de traiter le trafic pour tous les ports permet également de recevoir des fragments UDP dépourvus d'informations de port. Pour configurer tous les ports, utilisez Google Cloud CLI pour définir--ports=ALLou l'API pour définirallPortssurTrueConfiguration du service de backend : Définissez l'affinité de session du service de backend sur
CLIENT_IP(hachage à deux tuples) ouCLIENT_IP_PROTO(hachage à trois tuples) de sorte que le même backend soit sélectionné pour les paquets UDP incluant des informations de port et pour les fragments UDP (autres que le premier fragment) dépourvus d'informations de port. Définissez le mode de suivi des connexions du service de backend surPER_SESSIONafin que les entrées de la table de suivi des connexions soient créées à l'aide des mêmes hachages à deux ou trois tuples.
Tester à partir d'un seul client
Lorsque vous testez un équilibreur de charge réseau passthrough externe à partir d'un seul client, gardez les points suivants à l'esprit :
Si la VM cliente n'est pas un backend de l'équilibreur de charge : les nouvelles connexions sont traitées comme décrit dans les étapes de la section Sélection du backend et suivi des connexions. À l'étape Sélectionner un backend éligible, l'équilibreur de charge crée un hachage des caractéristiques des paquets en fonction de l'affinité de session.
N'oubliez pas que toutes les options d'affinité de session reposent au moins sur l'adresse IP du client. Les connexions provenant du même client peuvent être distribuées au même backend éligible plus souvent que prévu. Par conséquent, vous ne pouvez pas modéliser précisément la distribution globale des nouvelles connexions en vous connectant à un équilibreur de charge réseau passthrough externe à partir d'un seul client.
Si la VM cliente est également une VM de backend de l'équilibreur de charge : les nouvelles connexions ne sont pas traitées par l'équilibreur de charge. Les paquets sortants dont l'adresse IP de destination correspond à celle de la règle de transfert de l'équilibreur de charge sont acheminés localement dans l'OS invité du client en raison de la présence d'une route locale pour la règle de transfert.
Étapes suivantes
- Pour configurer un équilibreur de charge réseau passthrough externe avec un service de backend pour le trafic TCP ou UDP uniquement (compatible avec le trafic IPv4 et IPv6), consultez la page Configurer un équilibreur de charge réseau passthrough externe avec un service de backend.
- Pour configurer un équilibreur de charge réseau passthrough externe pour plusieurs protocoles IP (compatible avec le trafic IPv4 et IPv6), consultez la page Configurer un équilibreur de charge réseau passthrough externe pour plusieurs protocoles IP.
- Pour configurer un équilibreur de charge réseau passthrough externe avec un backend de NEG zonal, consultez la page Configurer un équilibreur de charge réseau passthrough externe avec des NEG zonaux.
- Pour découvrir comment passer d'un équilibreur de charge réseau passthrough externe d'un backend de pool cible vers un service de backend régional, consultez la page Migrer un équilibreur de charge réseau passthrough externe depuis un pool cible vers un service de backend.