Erweitertes Load Balancing einrichten
Dieses Dokument enthält eine Anleitung zum Einrichten der erweiterten Load Balancing-Optionen, die in der Übersicht über das erweiterte Load Balancing beschrieben werden. Dieses Dokument richtet sich an Nutzer, die mindestens grundlegende Kenntnisse von Cloud Service Mesh und Load Balancing-Konzepten haben.
Hinweise
Aktualisieren Sie die Google Cloud CLI, um sicherzustellen, dass Sie die neueste Version verwenden:
gcloud components update
Erstellen Sie einen neuen Back-End-Dienst oder entscheiden Sie, welchen vorhandenen Back-End-Dienst Sie für das erweiterte Load Balancing verwenden möchten.
Verwenden Sie den folgenden Befehl, um einen neuen Backend-Dienst namens hello-world-backend-service
zu erstellen:
gcloud compute backend-services create hello-world-backend-service \ --global \ --protocol=HTTP \ --health-checks hello-world-health-check \ --load-balancing-scheme=INTERNAL_SELF_MANAGED
Load Balancing-Richtlinie für Dienste mit YAML erstellen
Sie können Load-Balancing-Richtlinien für Dienste in einer YAML-Datei definieren. So richten Sie beispielsweise in einer Datei namens hello-world-lb-policy
eine Richtlinie ein, um die Funktion zum automatischen Kapazitätsentzug zu aktivieren:
name: projects/${project-id}/locations/global/serviceLbPolicies/hello-world-lb-policy autoCapacityDrain: enable: True
Nachdem Sie die YAML-Datei erstellt haben, importieren Sie sie:
gcloud network-services service-lb-policies import hello-world-lb-policy \ --source=hello-world-lb-policy.yaml \ --location=global
Verknüpfen Sie abschließend die Load-Balancing-Richtlinie für Dienste mit dem Backend-Dienst:
gcloud compute backend-services update hello-world-backend-service \ --service-lb-policy hello-world-lb-policy \ --global
Alternativ können Sie beim Erstellen eines Backend-Dienstes eine vorhandene Load-Balancing-Richtlinie für Dienste mit dem Backend-Dienst verknüpfen:
gcloud compute backend-services create hello-world-backend-service \ --global \ --protocol=HTTP \ --health-checks hello-world-health-check \ --load-balancing-scheme=INTERNAL_SELF_MANAGED \ --service-lb-policy hello-world-lb-policy
Diese Anleitung deckt nur Änderungen an der Back-End-Dienstressource ab. Ihre Cloud Service Mesh-Bereitstellung muss außerdem eine Systemdiagnose und Firewallregeln enthalten. Außerdem müssen Sie nach Bedarf Backends hinzufügen.
Algorithmus für die Zufallsverteilung in Regionen konfigurieren
Wenn Sie den Algorithmus „Spray-to-Region“ konfigurieren möchten, der den Traffic auf alle Zonen in einer Region verteilt, erstellen Sie eine Dienst-Load-Balancing-Richtlinie in einer Datei namens hello-world-lb-policy.yaml
:
name: projects/${project-id}/locations/global/serviceLbPolicies/hello-world-lb-policy loadBalancingAlgorithm: SPRAY_TO_REGION
Importieren Sie die YAML-Datei:
gcloud network-services service-lb-policies import hello-world-lb-policy \ --source=hello-world-lb-policy.yaml \ --location=global
Sie können diesen Algorithmus auch mit der gcloud CLI konfigurieren:
gcloud network-services service-lb-policies create hello-world-lb-policy \ --load-balancing-algorithm=SPRAY_TO_REGION \ --location=global
Algorithmus für die abfolgebasierte Vermittlung nach Zone konfigurieren
Wenn Sie den Algorithmus „Wasserfall nach Zone“ konfigurieren möchten, der Traffic an die lokale Zone sendet, bevor er an andere Zonen weitergeleitet wird, erstellen Sie eine Dienst-Load-Balancing-Richtlinie in einer Datei namens hello-world-lb-policy.yaml
:
name: projects/${project-id}/locations/global/serviceLbPolicies/hello-world-lb-policy loadBalancingAlgorithm: WATERFALL_BY_ZONE
Importieren Sie die YAML-Datei:
gcloud network-services service-lb-policies import hello-world-lb-policy \ --source=hello-world-lb-policy.yaml \ --location=global
Sie können diesen Algorithmus auch mit der gcloud CLI konfigurieren:
gcloud network-services service-lb-policies create hello-world-lb-policy \ --load-balancing-algorithm=WATERFALL_BY_ZONE \ --location=global
Bevorzugte Back-Ends konfigurieren
So konfigurieren Sie bevorzugte Back-Ends:
name: projects/${project-id}/locations/global/backendServices/hello-world-service ... backends: ... preference: PREFERRED
Im folgenden Beispiel sind drei Backends zu sehen: MIG1
, MIG2
und MIG3
:
name: .. ... - backends name: MIG1 preference: PREFERRED - backends name: MIG2 preference: DEFAULT - backends name: MIG3 ...
Sie können diese Funktion auch mit der gcloud CLI konfigurieren:
gcloud compute backend-services add-backend BACKEND_SERVICE_NAME \ [...] --preference=PREFERRED \ --global
So aktualisieren Sie die bevorzugten Back-Ends:
gcloud compute backend-services update-backend BACKEND_SERVICE_NAME \ [...] --preference=PREFERRED
Automatischen Kapazitätsausgleich konfigurieren
Wenn Sie Cloud Service Mesh so konfigurieren möchten, dass ein Back-End basierend auf seinem Zustand automatisch entlastet wird, erstellen Sie eine Load-Balancing-Richtlinie für Dienste. Gehen Sie dazu so vor:
name: projects/${project-id}/locations/global/serviceLbPolicies/hello-world-lb-policy autoCapacityDrain: enable: True
Sie können diese Funktion auch mit der gcloud CLI konfigurieren:
gcloud network-services service-lb-policies create capacity-drain-policy \ --auto-capacity-drain \ --location=global
Failover-Verhalten anpassen
Wenn Sie Cloud Service Mesh für einen bestimmten Wert für den Failover-Grenzwert für den Zustand konfigurieren möchten, fügen Sie Folgendes in eine Dienst-Load-Balancing-Richtlinie ein und ersetzen Sie VALUE
durch einen Wert zwischen 1 und 99. Die Standardwerte sind 50 für Cloud Service Mesh mit proxylosem gRPC und 70 für Cloud Service Mesh mit Envoy.
projects/${project-id}/locations/global/serviceLbPolicies/hello-world-lb-policy failoverConfig: failoverHealthThreshold: VALUE
So passen Sie das Failover-Verhalten mit der gcloud CLI an:
gcloud network-services service-lb-policies create failover-health-threshold--policy \ --failover-health-threshold=VALUE \ --location=global