Projekt und Cluster selbst einrichten
Wenn Sie Cloud Service Mesh mit asmcli
installieren, kann es Ihr Projekt und Ihren Cluster für Sie konfigurieren, wenn Sie das Flag --enable_all
oder die detaillierteren Aktivierungs-Flags angeben.
Folgen Sie der Anleitung auf dieser Seite, wenn Sie die Änderungen lieber selbst vornehmen möchten, statt dass asmcli
die Änderungen vornimmt.
Wenn Sie bereits eine frühere Version von Cloud Service Mesh installiert haben,
Änderungen an Ihrem Projekt oder Cluster vornehmen, bevor
asmcli
für Upgrade auf die neueste Version
Cloud Service Mesh-Version.
Standardmäßig installiert asmcli
das istio-ingressgateway
nicht. Wir empfehlen, die Steuerungsebene und die Gateways separat bereitzustellen und zu verwalten.
Cloud Service Mesh unterstützt die automatische Injektion für Gateway-Bereitstellungen, wodurch Cloud Service Mesh-Upgrades vereinfacht werden. Nach dem Upgrade von Cloud Service Mesh starten Sie die Gateways genau wie Ihre Dienste neu, um die neue Konfiguration der Steuerungsebene zu übernehmen.
Weitere Informationen finden Sie unter Gateways installieren und aktualisieren.
Hinweise
- Voraussetzungen und Anforderungen prüfen (außerhalb von Google Cloud, GKE)
- Installation planen (außerhalb von Google Cloud, GKE) oder das Upgrade
- Erforderliche Tools installieren (außerhalb von Google Cloud, GKE)
Projekt einrichten
Rufen Sie die Projekt-ID für das Projekt ab, in dem der Cluster ausgeführt wurde. erstellt in.
gcloud
Führen Sie dazu diesen Befehl aus:
gcloud projects list
Console
Wechseln Sie in der Google Cloud Console zur Seite Dashboard.
Klicken Sie oben auf der Seite auf die Drop-down-Liste. Wählen Sie im angezeigten Fenster Auswählen aus Ihr Projekt aus.
Die Projekt-ID wird auf der Dashboard-Karte Projektinformationen des Projekts angezeigt.
Erstellen Sie mit der Projekt-ID eine Umgebungsvariable für den Arbeitslastpool:
export WORKLOAD_POOL=PROJECT_ID.svc.id.goog
Legen Sie die erforderlichen IAM-Rollen (Identitäts- und Zugriffsverwaltung) fest. Wenn Sie Projektinhaber sind, haben Sie alle erforderlichen Berechtigungen, um die Installation abzuschließen. Wenn Sie kein Projektinhaber sind, benötigen Sie jemanden, der Ihnen die folgenden spezifischen IAM-Rollen zuweisen kann. Im ersetzen Sie
PROJECT_ID
durch den Projekt-ID aus dem vorherigen Schritt undGCP_EMAIL_ADDRESS
mit dem Konto, mit dem Sie sich in Google Cloud anmelden.ROLES=( 'roles/servicemanagement.admin' \ 'roles/serviceusage.serviceUsageAdmin' \ 'roles/meshconfig.admin' \ 'roles/compute.admin' \ 'roles/container.admin' \ 'roles/resourcemanager.projectIamAdmin' \ 'roles/iam.serviceAccountAdmin' \ 'roles/iam.serviceAccountKeyAdmin' \ 'roles/gkehub.admin') for role in "${ROLES[@]}" do gcloud projects add-iam-policy-binding PROJECT_ID \ --member "user:GCP_EMAIL_ADDRESS" \ --role="$role" done
Wenn Sie beim Ausführen von
asmcli
das Flag--enable_all
oder--enable_gcp_iam_roles
angeben, werden die erforderlichen IAM-Rollen für Sie festgelegt.Aktivieren Sie die erforderlichen Google APIs:
gcloud services enable \ --project=PROJECT_ID \ mesh.googleapis.com
Neben
mesh.googleapis.com
werden mit diesem Befehl auch folgende APIs aktiviert:API Zweck Kann deaktiviert werden? meshconfig.googleapis.com
Cloud Service Mesh verwendet die Mesh Configuration API, um Konfigurationsdaten von Ihrem Mesh an Google Cloud weiterzuleiten. Darüber hinaus können Sie durch Aktivieren der Mesh Configuration API auf die Cloud Service Mesh-Seiten in der Google Cloud Console zugreifen und die Cloud Service Mesh-Zertifizierungsstelle verwenden. Nein meshca.googleapis.com
Bezieht sich auf die Cloud Service Mesh-Zertifizierungsstelle, die vom verwalteten Cloud Service Mesh verwendet wird. Nein container.googleapis.com
Erforderlich zum Erstellen von Google Kubernetes Engine-Clustern (GKE). Nein gkehub.googleapis.com
Erforderlich zum Verwalten des Mesh-Netzwerks als Flotte. Nein monitoring.googleapis.com
Erforderlich zum Erfassen von Telemetrie für Mesh-Arbeitslasten. Nein stackdriver.googleapis.com
Erforderlich für die Verwendung der Dienste-UI. Nein opsconfigmonitoring.googleapis.com
Erforderlich, um die Dienste-UI für Cluster außerhalb von Google Cloud zu verwenden. Nein connectgateway.googleapis.com
Erforderlich, damit die verwaltete Cloud Service Mesh-Steuerungsebene auf Mesh-Arbeitslasten zugreifen kann. Ja* trafficdirector.googleapis.com
Ermöglicht eine hochverfügbare und skalierbare verwaltete Steuerungsebene. Ja* networkservices.googleapis.com
Ermöglicht eine hochverfügbare und skalierbare verwaltete Steuerungsebene. Ja* networksecurity.googleapis.com
Ermöglicht eine hochverfügbare und skalierbare verwaltete Steuerungsebene. Ja* Die Aktivierung der APIs kann einige Minuten dauern. Wenn die APIs aktiviert sind, sieht die Ausgabe in etwa so aus:
Operation "operations/acf.601db672-88e6-4f98-8ceb-aa3b5725533c" finished successfully.
Wenn Sie beim Ausführen von
asmcli
das Flag--enable_all
oder--enable_apis
angeben, werden die erforderlichen APIs für Sie aktiviert.
Cluster einrichten
Wenn Sie den Parameter-Flag --enable_all
oder einen der detaillierteren
Flags für die Aktivierung einschließen, richtet das asmcli
-Skript Ihren Cluster für Sie ein.
Initialisieren Sie Ihr Projekt, um es für die Installation vorzubereiten. Mit diesem Befehl wird unter anderem ein Dienstkonto erstellt, mit dem Komponenten der Datenebene, wie der Sidecar-Proxy, sicher auf die Daten und Ressourcen Ihres Projekts zugreifen können. Ersetzen Sie im folgenden Befehl
FLEET_PROJECT_ID
durch das Flottenhostprojekt.curl --request POST \ --header "Authorization: Bearer $(gcloud auth print-access-token)" \ --header "Content-Type: application/json" \ --data '{"workloadIdentityPools":["FLEET_PROJECT_ID.hub.id.goog","FLEET_PROJECT_ID.svc.id.goog","PROJECT_ID.svc.id.goog"]}' \ "https://meshconfig.googleapis.com/v1alpha1/projects/PROJECT_ID:initialize"
Der Befehl gibt ein Paar leere geschweifte Klammern zurück:
{}
Legen Sie für GKE-Cluster in Google Cloud die Standardzone oder -region für die Google Cloud CLI fest. Wenn Sie hier keine Standardeinstellung festlegen, müssen Sie in den
gcloud container clusters
-Befehlen auf dieser Seite entweder die Option--zone
oder--region
angeben.Wenn Sie einen Cluster mit einer einzelnen Zone haben, legen Sie die Standardzone fest:
gcloud config set compute/zone CLUSTER_LOCATION
Wenn Sie einen regionalen Cluster haben, legen Sie die Standardregion fest:
gcloud config set compute/region CLUSTER_LOCATION
Aktivieren Sie für GKE in Google Cloud-Clustern Workload Identity:
gcloud container clusters update CLUSTER_NAME \ --project=PROJECT_ID \ --workload-pool=${WORKLOAD_POOL}
Die Aktivierung von Workload Identity kann bis zu 10 bis 15 Minuten dauern.
Aktivieren Sie für GKE in Google Cloud-Clustern Cloud Monitoring und Cloud Logging in GKE:
gcloud container clusters update CLUSTER_NAME \ --project=PROJECT_ID \ --enable-stackdriver-kubernetes
Ihr Projekt und Ihr Cluster sind jetzt für eine neue Installation mit asmcli
bereit.
Nächste Schritte
- Abhängige Tools installieren und Cluster außerhalb von Google Cloud validieren
- Abhängige Tools installieren und Cluster in GKE validieren