Équilibrage de charge Cloud Service Mesh
Cloud Service Mesh utilise des proxys side-car ou gRPC sans proxy pour transmettre la charge globale pour vos microservices internes. Vous pouvez déployer des microservices internes (basés sur un proxy side-car ou gRPC sans proxy) avec des instances situées dans plusieurs régions. Cloud Service Mesh fournit des informations d'état, de routage et de backend aux proxys side-car ou gRPC sans proxy, ce qui leur permet d'effectuer un routage optimal du trafic d'un service vers les instances d'application dans plusieurs régions cloud.
Dans le schéma suivant, le trafic utilisateur entre dans un déploiement Google Cloud via un équilibreur de charge global externe. L'équilibreur de charge externe répartit le trafic vers le microservice Front End dans us-central1
ou asia-southeast1
, en fonction de l'emplacement de l'utilisateur final.
Le déploiement interne comprend trois microservices mondiaux : Front End, Shopping Cart et Payments. Chaque service s'exécute sur des groupes d'instances gérés (MIG) dans deux régions, us-central1
et asia-southeast1
. Cloud Service Mesh utilise un algorithme d'équilibrage de charge global qui dirige le trafic de l'utilisateur californien vers les microservices déployés dans us-central1
. Les requêtes de l'utilisateur à Singapour sont dirigées vers les microservices de asia-southeast1
.
La requête entrante d'un utilisateur est acheminée vers le microservice Front End. Le proxy de service installé sur l'hôte avec Front End dirige ensuite le trafic vers le microservice Shopping Cart. Le proxy de service installé sur l'hôte avec Shopping Cart achemine le trafic vers le microservice Payments. Dans un environnement gRPC sans proxy, votre application gRPC gère le trafic.
Dans l'exemple suivant, si Cloud Service Mesh reçoit les résultats de la vérification de l'état
indiquant que les instances de machine virtuelle (VM) exécutant le panier
microservices dans us-central1
ne sont pas opérationnels, Cloud Service Mesh indique au
un proxy side-car permettant aux microservices Front End de basculer le trafic vers
Microservice de panier s'exécutant dans asia-southeast1
. Étant donné que l'autoscaling est intégré à la gestion du trafic dans Google Cloud, Cloud Service Mesh informe le MIG dans asia-southeast1
du trafic supplémentaire, qui augmente sa taille.
Cloud Service Mesh détecte que tous les backends du microservice Payments sont opérationnels. Il charge donc le proxy Envoy du microservice Shopping Cart d'envoyer une partie du trafic, jusqu'à la capacité configurée du client, à la région asia-southeast1
et d'envoyer le reste à la région us-central1
.
Composants d'équilibrage de charge dans Cloud Service Mesh
Lors de la configuration de Cloud Service Mesh, vous configurez plusieurs composants d'équilibrage de charge :
- Le service de backend, qui contient les valeurs de configuration.
- Une vérification de l'état, qui fournit une vérification de l'état pour les VM et les pods Google Kubernetes Engine (GKE) dans votre déploiement.
- Avec les API de routage des services, une ressource
Mesh
ouGateway
et une ressourceRoute
. - Avec les API d'équilibrage de charge, une règle de transfert globale, qui inclut l'adresse IP virtuelle, un proxy cible et un mappage d'URL.
Un proxy side-car compatible avec l'API xDS (tel qu'Envoy) s'exécute sur un client
une instance de VM ou un pod Kubernetes. Cloud Service Mesh sert de service de contrôle
et utilise des API xDS pour communiquer directement avec chaque proxy. Dans les données
l'application envoie du trafic à l'adresse IP virtuelle configurée dans
une règle de transfert ou une ressource Mesh
. Le proxy side-car ou votre application gRPC
intercepte le trafic et le redirige vers le backend approprié.
Le schéma suivant illustre une application s'exécutant sur des VM Compute Engine ou les pods GKE, les composants et le flux de trafic Déploiement de Cloud Service Mesh Elle montre Cloud Service Mesh et Ressources Cloud Load Balancing permettant de déterminer le routage du trafic. Le schéma montre les anciennes API d'équilibrage de charge.
Étape suivante
- Pour en savoir plus sur la configuration des fonctionnalités avancées d'équilibrage de charge, consultez Présentation de l'équilibrage de charge avancé
- Pour en savoir plus sur la détection de services et l'interception du trafic, consultez la page Détection de services Cloud Service Mesh.
- Pour en savoir plus sur Cloud Service Mesh avec les API de routage de services, consultez la présentation.