Wenn Sie Dienste in mehreren Regionen bereitstellen und Nutzer an die nächstgelegene Region weiterleiten, können Sie ihnen weltweit schneller Antworten liefern. Die Bereitstellung über mehrere Regionen hinweg sorgt für eine geringe Latenz und eine höhere Verfügbarkeit bei regionalen Ausfällen.
Da Cloud Run-Dienste in einzelnen Regionen bereitgestellt werden, müssen Sie Ihren Dienst in mehreren Regionen bereitstellen und dann das globale Load Balancing für den Dienst konfigurieren.
Dienst in mehreren Regionen bereitstellen
Sie können denselben Dienst mit einer der folgenden Methoden in mehreren Regionen bereitstellen:
- Wiederholen Sie die Schritte zur Bereitstellung in einer einzelnen Region.
- Stellen Sie einen multiregionalen Dienst bereit.
Multiregionalen Dienst bereitstellen
In diesem Abschnitt erfahren Sie, wie Sie einen multiregionalen Dienst mit einem einzigen Befehl der gcloud CLI oder einer YAML-Datei bereitstellen und konfigurieren.
gcloud
Führen Sie den Befehl
gcloud beta run deploy
mit dem Flag--regions
aus, um einen multiregionalen Dienst für zu erstellen und bereitzustellen:gcloud beta run deploy
SERVICE_NAME
\ --image=IMAGE_URL
\ --regions=REGIONS
Ersetzen Sie Folgendes:
SERVICE_NAME
: Der Name des multiregionalen Dienstes, den Sie bereitstellen möchten.IMAGE_URL
: Ein Verweis auf das Container-Image, z. B.us-docker.pkg.dev/cloudrun/container/hello:latest
REGIONS
: Die Liste der Regionen, in denen Sie die Bereitstellung vornehmen möchten. Beispiel:us-central1,asia-east1
.
YAML
Erstellen Sie die YAML-Datei für Ihren Dienst und legen Sie mit dem Attribut
run.googleapis.com/regions
die Regionen fest, in denen Sie Ihren Dienst bereitstellen möchten:apiVersion: serving.knative.dev/v1 kind: Service metadata: name:
SERVICE_NAME
annotations: run.googleapis.com/launch-stage: BETA run.googleapis.com/regions:REGIONS
spec: template: spec: containers: - image:IMAGE_URL
Ersetzen Sie Folgendes:
SERVICE_NAME
: Der Name des multiregionalen Dienstes, in dem Sie die Bereitstellung vornehmen möchten.REGIONS
: Die Liste der Regionen, die Sie aktualisieren möchten. Beispiel:us-central1,asia-east1
.IMAGE_URL
: Ein Verweis auf das Container-Image, z. B.us-docker.pkg.dev/cloudrun/container/hello:latest
Erstellen Sie den Dienst mit dem folgenden Befehl:
gcloud beta run multi-region-services replace service.yaml
Multiregionalen Dienst aktualisieren
In diesem Abschnitt erfahren Sie, wie Sie einem multiregionalen Dienst mit einem einzigen Befehl der gcloud CLI oder einer YAML-Datei Regionen hinzufügen oder daraus entfernen.
gcloud
Wenn Sie einem multiregionalen Dienst Regionen hinzufügen oder daraus entfernen möchten, führen Sie den Befehl gcloud beta run multi-region-services update
aus.
Verwenden Sie das Flag
--add-regions
, um dem multiregionalen Dienst eine oder mehrere zusätzliche Regionen hinzuzufügen:gcloud beta run multi-region-services update
SERVICE_NAME
\ --add-regions=REGIONS
Verwenden Sie das Flag
--remove-regions
, um den multiregionalen Dienst aus einer oder mehreren Regionen zu entfernen:gcloud beta run multi-region-services update
SERVICE_NAME
\ --remove-regions=REGIONS
Ersetzen Sie Folgendes:
SERVICE_NAME
: Der Name des multiregionalen Dienstes, den Sie aktualisieren möchten.REGIONS
: Die Region oder Regionen, in denen Sie Ihren Dienst hinzufügen oder aus denen Sie ihn entfernen möchten. Beispiel:us-central1,asia-east1
YAML
Wenn Sie einen vorhandenen Dienst mit mehreren Regionen aktualisieren möchten, laden Sie die zugehörige YAML-Konfiguration herunter:
gcloud beta run multi-region-services describe SERVICE_NAME --format export > service.yaml
Aktualisieren Sie das Attribut
run.googleapis.com/regions
, um die Liste der Regionen hinzuzufügen oder daraus zu entfernen, in denen der Dienst bereitgestellt werden soll:apiVersion: serving.knative.dev/v1 kind: Service metadata: name:
SERVICE_NAME
annotations: run.googleapis.com/launch-stage: BETA run.googleapis.com/regions:REGIONS
Ersetzen Sie Folgendes:
SERVICE_NAME
: Der Name des multiregionalen Dienstes, in dem Sie die Bereitstellung vornehmen möchten.REGIONS
: Die neue Liste mit mehreren Regionen, in denen die Dienstversion bereitgestellt werden soll.
Aktualisieren Sie den Dienst mit dem folgenden Befehl:
gcloud beta run multi-region-services replace service.yaml
Multiregionalen Dienst löschen
Führen Sie den Befehl
gcloud beta run multi-region-services delete
aus, um einen multiregionalen Dienst zu löschen:gcloud beta run multi-region-services delete
SERVICE_NAME
Ersetzen Sie
SERVICE_NAME
durch den Namen des multiregionalen Dienstes, den Sie löschen möchten.
Globales Load Balancing konfigurieren
In diesem Abschnitt erfahren Sie, wie Sie einen externen Application Load Balancer mit einer Domain konfigurieren, die mit einem verwalteten TLS-Zertifikat geschützt wird und auf eine globale Anycast-IP-Adresse verweist. Über diese Adresse werden die Nutzer zum nächsten Google-Rechenzentrum weitergeleitet, in dem Ihr Dienst bereitgestellt ist.
Die in den folgenden Abschnitten beschriebene Architektur leitet Anfragen nicht automatisch an eine andere Region weiter, wenn ein regionaler Cloud Run-Dienst nicht mehr reagiert oder Fehler zurückgibt. Wenn Sie die Verfügbarkeit Ihres multiregionalen Dienstes erhöhen möchten, können Sie die Ausreißererkennung konfigurieren, um fehlerhafte Cloud Run-Dienste anhand ihrer HTTP-Fehlerrate zu identifizieren und einige Anfragen an eine andere Region weiterzuleiten.
Load-Balancer erstellen
Zum Erstellen eines externen Application Load Balancers müssen verschiedene Netzwerkressourcen erstellt und miteinander verbunden werden:
gcloud-CLI
- Reservieren Sie eine statische IP-Adresse, damit Sie Ihre DNS-Einträge bei der Neuerstellung Ihres Load-Balancers nicht aktualisieren müssen.
Ersetzen Sie im obigen Befehl SERVICE_IP durch einen Namen für die IP-Adressressource (z. B.gcloud compute addresses create --global SERVICE_IP
myservice-ip
).Diese IP-Adresse ist eine globale Anycast-IPv4-Adresse, über die eine Weiterleitung an das Google-Rechenzentrum oder an den Point of Presence erfolgt, der den Besuchern am nächsten liegt.
- Erstellen Sie einen Back-End-Dienst.
gcloud compute backend-services create --global BACKEND_NAME
Ersetzen Sie im obigen Befehl BACKEND_NAME durch einen Namen, den Sie dem Back-End-Dienst geben möchten (z. B.
myservice-backend
). - Erstellen Sie eine URL-Zuordnung.
gcloud compute url-maps create URLMAP_NAME --default-service=BACKEND_NAME
Ersetzen Sie URLMAP_NAME durch den Namen, den Sie der URL-Zuordnung zuweisen möchten (z. B.
myservice-urlmap
). - Erstellen Sie für Ihre Domain ein verwaltetes TLS-Zertifikat, um HTTPS-Traffic bereitzustellen. Ersetzen Sie example.com durch Ihren Domainnamen.
gcloud compute ssl-certificates create CERT_NAME \ --domains=example.com
Ersetzen Sie CERT_NAME durch den Namen, den das verwaltete SSL-Zertifikat haben soll (z. B.
myservice-cert
). - Erstellen Sie einen Ziel-HTTPS-Proxy.
gcloud compute target-https-proxies create HTTPS_PROXY_NAME \ --ssl-certificates=CERT_NAME \ --url-map=URLMAP_NAME
Ersetzen Sie HTTPS_PROXY_NAME durch den Namen, den Sie dem HTTPS-Ziel-Proxy geben möchten (z. B.
myservice-https
). - Erstellen Sie eine Weiterleitungsregel, um die von Ihnen erstellten Netzwerkressourcen mit der IP-Adresse zu verbinden.
gcloud compute forwarding-rules create --global FORWARDING_RULE_NAME \ --target-https-proxy=HTTPS_PROXY_NAME \ --address=SERVICE_IP \ --ports=443
Ersetzen Sie FORWARDING_RULE_NAME durch den Namen der Ressource für die Weiterleitungsregel, die Sie erstellen möchten (z. B.
myservice-lb
).
Terraform
Alternativ zu den in diesem Abschnitt beschriebenen Schritten können Sie das Terraform-Modul für globale HTTP-Load-Balancer verwenden.
Fügen Sie der Terraform-Datei Folgendes hinzu (z. B. main.tf
):
-
Konfigurieren Sie die IP-Adresse:
Der IP-Adressressourcenname wird als
myservice-service-ip
konfiguriert. Sie können das in Ihren eigenen Wert ändern. Diese IP-Adresse ist eine globale Anycast-IPv4-Adresse, über die eine Weiterleitung an das Google-Rechenzentrum oder an den Point of Presence erfolgt, der den Besuchern am nächsten liegt. -
Erstellen und konfigurieren Sie den Backend-Dienst:
Diese Ressource konfiguriert den Backend-Dienst sodas er
myservice-backend
heißt. Sie können das in Ihren eigenen Wert ändern. -
URL-Zuordnung konfigurieren
Verbindet die Backend-Dienstressource (
myservice-backend
) mit der neuen URL-Zuordnungsressource (myservice-lb-urlmap
). Sie können diese Werte in Ihre eigenen ändern. -
Erstellen Sie für Ihre Domain ein verwaltetes TLS-Zertifikat, um HTTPS-Traffic bereitzustellen. Ersetzen Sie
example.com
durch Ihren Domainnamen in der Ressourcegoogle_compute_managed_ssl_certificate
: -
Konfigurieren Sie den HTTPS-Proxy:
Erstellt die Ressource
google_compute_target_https_proxy
mit dem Zielnamenmyservice-https-proxy
und verbindet das zuvor erstellte TLS-Zertifikat (myservice-ssl-cert
) und die URL-Zuordnungsressourcen (myservice-lb-urlmap
). Sie können diese Werte in Ihre eigenen ändern. -
Weiterleitungsregel konfigurieren
Erstellt die Ressource
google_compute_global_forwarding_rule
mit dem Zielnamenmyservice-https-proxy
und verbindet das zuvor erstellte HTTPS-Proxy-Ziel (myservice-https-proxy
) und die IP-Adressressource (myservice-service-ip
). Sie können diese Werte in Ihre eigenen ändern. -
Wenden Sie diese Konfiguration an:
Führen Sie die Schritte in den folgenden Abschnitten aus, um Ihre Terraform-Konfiguration auf ein Google Cloud -Projekt anzuwenden.
Cloud Shell vorbereiten
- Rufen Sie Cloud Shell auf.
-
Legen Sie das Standardprojekt Google Cloud fest, auf das Sie Ihre Terraform-Konfigurationen anwenden möchten.
Sie müssen diesen Befehl nur einmal pro Projekt und in jedem beliebigen Verzeichnis ausführen.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
Umgebungsvariablen werden überschrieben, wenn Sie in der Terraform-Konfigurationsdatei explizite Werte festlegen.
Verzeichnis vorbereiten
Jede Terraform-Konfigurationsdatei muss ein eigenes Verzeichnis haben (auch als Stammmodul bezeichnet).
-
Erstellen Sie in Cloud Shell ein Verzeichnis und eine neue Datei in diesem Verzeichnis. Der Dateiname muss die Erweiterung
.tf
haben, z. B.main.tf
. In dieser Anleitung wird die Datei alsmain.tf
bezeichnet.mkdir DIRECTORY && cd DIRECTORY && touch main.tf
-
Wenn Sie einer Anleitung folgen, können Sie den Beispielcode in jedem Abschnitt oder Schritt kopieren.
Kopieren Sie den Beispielcode in das neu erstellte
main.tf
.Kopieren Sie optional den Code aus GitHub. Dies wird empfohlen, wenn das Terraform-Snippet Teil einer End-to-End-Lösung ist.
- Prüfen und ändern Sie die Beispielparameter, die auf Ihre Umgebung angewendet werden sollen.
- Speichern Sie die Änderungen.
-
Initialisieren Sie Terraform. Dies ist nur einmal für jedes Verzeichnis erforderlich.
terraform init
Fügen Sie optional die Option
-upgrade
ein, um die neueste Google-Anbieterversion zu verwenden:terraform init -upgrade
Änderungen anwenden
-
Prüfen Sie die Konfiguration und prüfen Sie, ob die Ressourcen, die Terraform erstellen oder aktualisieren wird, Ihren Erwartungen entsprechen:
terraform plan
Korrigieren Sie die Konfiguration nach Bedarf.
-
Wenden Sie die Terraform-Konfiguration an. Führen Sie dazu den folgenden Befehl aus und geben Sie
yes
an der Eingabeaufforderung ein:terraform apply
Warten Sie, bis Terraform die Meldung „Apply complete“ anzeigt.
- Öffnen Sie Ihr Google Cloud -Projekt, um die Ergebnisse aufzurufen. Rufen Sie in der Google Cloud Console Ihre Ressourcen in der Benutzeroberfläche auf, um sicherzustellen, dass Terraform sie erstellt oder aktualisiert hat.
Regionale Netzwerk-Endpunktgruppen konfigurieren
Für jede Region, in der Sie im vorherigen Schritt eine Bereitstellung vorgenommen haben, müssen Sie serverlose Netzwerk-Endpunktgruppen (NEGs) erstellen und diese dem Back-End-Dienst hinzufügen. Gehen Sie dazu folgendermaßen vor:
gcloud-CLI
-
Erstellen Sie eine Netzwerk-Endpunktgruppe für den Cloud Run-Dienst in
REGION
:gcloud compute network-endpoint-groups create NEG_NAME \ --region=REGION \ --network-endpoint-type=SERVERLESS \ --cloud-run-service=SERVICE_NAME
Ersetzen Sie Folgendes:
- NEG_NAME durch den Namen der Netzwerk-Endpunktgruppenressource (z. B. „myservice-neg-uscentral1“)
- REGION durch die [region][Standort], in der Ihr Dienst bereitgestellt wird.
- SERVICE_NAME durch den Namen des Dienstes.
-
Fügen Sie dem Back-End-Dienst die Netzwerk-Endpunktgruppe hinzu:
gcloud compute backend-services add-backend --global BACKEND_NAME \ --network-endpoint-group-region=REGION \ --network-endpoint-group=NEG_NAME
Geben Sie den Namen für NEG_NAME an, den Sie im vorherigen Schritt für die Region festgelegt haben.
-
Wiederholen Sie die vorherigen Schritte für jede Region.
Terraform
-
Konfigurieren Sie eine Netzwerk-Endpunktgruppe mit dem Namen
myservice-neg
für den Cloud Run-Dienst für jede Region, die in der Variablerun_regions
angegeben ist: -
Konfigurieren Sie einen Backend-Dienst, um die Netzwerk-Endpunktgruppe (
myservice-neg
) anzuhängen:
DNS-Einträge in Ihrer Domain konfigurieren
Damit der Domainname auf die von Ihnen erstellte Weiterleitungsregel verweist, aktualisieren Sie die DNS-Einträge mit der von Ihnen erstellten IP-Adresse.
Führen Sie den folgenden Befehl aus, um die reservierte IP-Adresse des Load Balancers zu ermitteln:
gcloud compute addresses describe \ --global=SERVICE_IP \ --format='value(address)'
Ersetzen Sie SERVICE_IP durch den Namen der zuvor erstellten IP-Adresse. Mit diesem Befehl wird die IP-Adresse in der Ausgabe angegeben.
Aktualisieren Sie die DNS-Einträge Ihrer Domain. Fügen Sie dazu einen
A
-Eintrag mit dieser IP-Adresse hinzu.
Benutzerdefinierte Zielgruppe bei Verwendung authentifizierter Dienste konfigurieren
Authentifizierte Dienste sind durch IAM geschützt. Solche Cloud Run-Dienste erfordern eine Clientauthentifizierung, die den vorgesehenen Empfänger einer Anfrage zum Zeitpunkt der Erstellung von Anmeldedaten deklariert (die Zielgruppe).
Das Ziel ist in der Regel die vollständige URL des Zieldienstes, die für Cloud Run-Dienste standardmäßig eine generierte URL ist, die auf run.app
endet. Bei einer Bereitstellung in mehreren Regionen kann ein Client jedoch nicht im Voraus wissen, an welchen regionalen Dienst eine Anfrage weitergeleitet wird.
Konfigurieren Sie Ihren Dienst für eine multiregionale Bereitstellung so, dass benutzerdefinierte Zielgruppen verwendet werden.
Auf Bereitstellung des Load-Balancers warten
Nachdem Sie die Domain mit der IP-Adresse des Load Balancers konfiguriert haben, müssen Sie warten, bis DNS-Einträge übernommen werden. Ebenso müssen Sie warten, bis das verwaltete TLS-Zertifikat für Ihre Domain ausgestellt wurde und bereit ist, HTTPS-Traffic weltweit bereitzustellen.
Es kann bis zu 30 Minuten dauern, bis der Load-Balancer Traffic bereitstellt.
Anschließend können Sie testweise die Website über die URL mit dem Präfix https://
aufrufen.
Status bestätigen
So prüfen Sie den Status der Weitergabe von DNS-Einträgen mit dem
dig
-Befehlszeilen-Dienstprogramm:dig A +short example.com
Die Ausgabe zeigt die IP-Adresse, die Sie in Ihren DNS-Einträgen konfiguriert haben.
Führen Sie folgenden Befehl aus, um den Status der Ausstellung Ihres verwalteten Zertifikats zu prüfen:
gcloud compute ssl-certificates describe CERT_NAME
Ersetzen Sie CERT_NAME durch den Namen, den Sie zuvor für die SSL-Zertifikatsressource ausgewählt haben.
Die Ausgabe sollte eine Zeile mit
status: ACTIVE
enthalten.
HTTP-zu-HTTPS-Weiterleitung einrichten
Standardmäßig verarbeitet eine Weiterleitungsregel nur ein einzelnes Protokoll, sodass bei Anfragen an Ihre http://
-Endpunkte die Meldung „404 Nicht gefunden“ angezeigt wird. Wenn Anfragen an Ihre http://
-URLs zum https://
-Protokoll weitergeleitet werden sollen, erstellen Sie mithilfe der folgenden Anleitung eine zusätzliche URL-Zuordnung und eine Weiterleitungsregel:
gcloud-CLI
-
Erstellen Sie eine URL-Zuordnung mit einer Weiterleitungsregel.
gcloud compute url-maps import HTTP_URLMAP_NAME \ --global \ --source /dev/stdin <<EOF name: HTTP_URLMAP_NAME defaultUrlRedirect: redirectResponseCode: MOVED_PERMANENTLY_DEFAULT httpsRedirect: True EOF
Ersetzen Sie dabei HTTP_URLMAP_NAME durch den Namen der URL-Zuordnungsressource, die Sie erstellen möchten, z. B.
myservice-httpredirect
. -
Erstellen Sie einen HTTP-Ziel-Proxy mit der URL-Zuordnung.
gcloud compute target-http-proxies create HTTP_PROXY_NAME \ --url-map=HTTP_URLMAP_NAME
Ersetzen Sie dabei HTTP_PROXY_NAME durch den Namen des HTTP-Ziel-Proxys, den Sie erstellen möchten, z. B.
myservice-http
. -
Erstellen Sie eine Weiterleitungsregel auf Port
80
mit derselben reservierten IP-Adresse.gcloud compute forwarding-rules create --global HTTP_FORWARDING_RULE_NAME \ --target-http-proxy=HTTP_PROXY_NAME \ --address=SERVICE_IP \ --ports=80
Ersetzen Sie dabei HTTP_FORWARDING_RULE_NAME durch den Namen der neuen Weiterleitungsregel, die Sie erstellen möchten, z. B.
myservice-httplb
.
Terraform
-
Erstellen Sie eine URL-Zuordnungsressource mit einer Weiterleitungsregel.
-
Erstellen Sie einen HTTP-Ziel-Proxy mit der neu erstellten URL-Zuordnungsressource (
myservice-https-urlmap
): -
Erstellen Sie eine Weiterleitungsregel auf Port
80
mit derselben reservierten IP-Adressen-Ressource (myservice-http-proxy
).
Authentifizierte Pub/Sub-Push-Abos mit Bereitstellung in mehreren Regionen verwenden
Ein Pub/Sub-Dienst sendet standardmäßig Nachrichten an Push-Endpunkte in derselben Google Cloud -Region, in der der Pub/Sub-Dienst die Nachrichten speichert. Eine Behelfslösung für dieses Verhalten finden Sie unter Authentifiziertes Pub/Sub-Push-Abo mit einer Cloud Run-Bereitstellung für mehrere Regionen verwenden.
Manuellen Failover konfigurieren
Wenn Sie den Traffic manuell so konfigurieren möchten, dass er auf eine fehlerfreie Region umgeleitet wird, ändern Sie die URL-Zuordnung des globalen externen Application Load Balancers.
Wenn Sie die URL-Zuordnung des globalen externen Application Load Balancers aktualisieren möchten, entfernen Sie die NEG mit dem Flag
--global
aus dem Backend-Dienst:gcloud compute backend-services remove-backend
BACKEND_NAME
\ --network-endpoint-group=NEG_NAME
\ --network-endpoint-group-region=REGION
\ --globalErsetzen Sie Folgendes:
BACKEND_NAME
ist der Name des Backend-Dienstes.NEG_NAME
: Der Name der Netzwerk-Endpunktgruppenressource, z. B.myservice-neg-uscentral1
.REGION
: Die Region, in der die NEG erstellt wurde und aus der Sie Ihren Dienst entfernen möchten. Beispiel:us-central1,asia-east1
Rufen Sie https://
<domain-name>
auf, um zu prüfen, ob eine fehlerfreie Region jetzt Traffic bereitstellt.