BookInfo-Beispiel bereitstellen
Auf dieser Seite wird beschrieben, wie Sie eine Beispielanwendung bereitstellen, um Cloud Service Mesh zu demonstrieren. Wenn Sie Cloud Service Mesh nicht installiert haben, lesen Sie die Installationsanleitung.
In der Cloud Service Mesh-Installation sind mehrere Beispielanwendungen enthalten. In dieser Anleitung wird beschrieben, wie Sie das Beispiel BookInfo bereitstellen. Dies ist die Simulation einer einfachen Anwendung für den Buchhandel, die aus vier Diensten besteht: einer Webproduktseite, Buchdetails, Rezensionen (mit mehreren Versionen des Rezensionsdienstes) und Bewertungen. Alle werden mit Cloud Service Mesh verwaltet. Den Quellcode und alle anderen Dateien in diesem Beispiel finden Sie im Verzeichnis samples/bookinfo Ihrer Cloud Service Mesh-Installation.
Automatisches Einschleusen der Sidecar-Datei aktivieren
Wenn Sie die automatische Sidecar-Injektion aktivieren möchten, müssen Sie Ihre Namespaces so kennzeichnen, dass der Sidecar-Injektor-Webhook eingefügte Sidecars mit einer bestimmten Überarbeitung der Steuerungsebene verknüpft. Wenn Sie das Standard-Tag eingerichtet haben, versehen Sie Ihre Namespaces mit den Standard-Injektionslabels. Andernfalls müssen Sie Ihre Namespaces mit dem Überarbeitungslabel kennzeichnen. Welches Label Sie hinzufügen, hängt davon ab, ob Sie verwaltetes Cloud Service Mesh oder die clusterinterne Steuerungsebene installiert haben.
Verwaltet
Sie können entweder das Standard-Injektionslabel oder das Überarbeitungslabel für Ihren Namespace verwenden.
Standard-Injektionslabels
Wenden Sie das Standard-Injektionslabel auf den Namespace an.
kubectl label namespace NAMESPACE istio-injection=enabled istio.io/rev-Überarbeitungslabel
Entfernen Sie vor dem Bereitstellen von Anwendungen alle vorherigen
istio-injection-Labels aus ihren Namespaces und legen Sie stattdessen das Labelistio.io/rev=REVISION_LABELfest.Wenn Sie es in ein bestimmtes Überarbeitungslabel ändern möchten, klicken Sie auf
REVISION_LABELund ersetzen Sie es durch das entsprechende Label:asm-managed-rapidfür den Rapid-Channel,asm-managedfür den Regular-Channel oderasm-managed-stablefür den Stable-Channel.Das Überarbeitungslabel entspricht einer Release-Version:
Überarbeitungslabel Kanal asm-managedRegulär asm-managed-rapidRapid asm-managed-stableStabil kubectl label namespace NAMESPACE istio-injection- istio.io/rev=REVISION_LABEL --overwriteWenn Sie auch die optionale verwaltete Datenebene bereitgestellt haben, annotieren Sie den Namespace
NAMESPACEso:kubectl annotate --overwrite namespace NAMESPACE \ mesh.cloud.google.com/proxy='{"managed":"true"}'
Clusterintern
Verwenden Sie den folgenden Befehl, um das Überarbeitungslabel für
istiodzu finden:kubectl -n istio-system get pods -l app=istiod --show-labelsDie Ausgabe sieht dann ungefähr so aus:
NAME READY STATUS RESTARTS AGE LABELS istiod-asm-173-3-5788d57586-bljj4 1/1 Running 0 23h app=istiod,istio.io/rev=asm-11910-9,istio=istiod,pod-template-hash=5788d57586 istiod-asm-173-3-5788d57586-vsklm 1/1 Running 1 23h app=istiod,istio.io/rev=asm-11910-9,istio=istiod,pod-template-hash=5788d57586Notieren Sie sich den Wert des Überarbeitungslabels
istiodaus der Ausgabe in der SpalteLABELS, das auf das Präfixistio.io/rev=folgt. In diesem Beispiel ist der Wertasm-11910-9.Wenden Sie das Überarbeitungslabel auf den Standard-Namespace an. Im folgenden Befehl ist
REVISIONder Wert des Revisions-Labelsistiod, den Sie im vorherigen Schritt notiert haben.kubectl label namespace default istio-injection- istio.io/rev=REVISION --overwriteSie können die Nachricht
"istio-injection not found"in der Ausgabe ignorieren. Das bedeutet, dass der Namespace bisher nicht das Labelistio-injectionhatte, was bei Neuinstallationen von Cloud Service Mesh oder neuen Bereitstellungen zu erwarten wäre. Da das Verhalten bei der automatischen Injektion nicht definiert ist, wenn ein Namespace sowohl das Labelistio-injectionals auch das Überarbeitungslabel hat, wird bei allenkubectl label-Befehlen in der Cloud Service Mesh-Dokumentation explizit darauf geachtet, dass nur eines der beiden Labels festgelegt ist.
Anwendung bereitstellen
Nachdem im Namespace default die automatische Einschleusung aktiviert wurde, werden beim Bereitstellen der Dienste für die BookInfo-Anwendung mit jedem Dienst Sidecar-Proxys eingeschleust.
Wechseln Sie in der Befehlszeile des Computers, auf dem Cloud Service Mesh installiert ist, zum Stamm des Cloud Service Mesh-Installationsverzeichnisses. Laden Sie bei Bedarfdie Installationsdatei herunter.
Stellen Sie die Anwendung mit
kubectlim Standard-Namespace bereit:kubectl apply -f samples/bookinfo/platform/kube/bookinfo.yamlFühren Sie die folgenden Befehle aus, um zu bestätigen, dass die Anwendung fehlerfrei bereitgestellt wurde:
kubectl get servicesAusgabe:
NAME CLUSTER-IP EXTERNAL-IP PORT(S) AGE details 10.0.0.31 <none> 9080/TCP 6m kubernetes 10.0.0.1 <none> 443/TCP 7d productpage 10.0.0.120 <none> 9080/TCP 6m ratings 10.0.0.15 <none> 9080/TCP 6m reviews 10.0.0.170 <none> 9080/TCP 6m
und
kubectl get podAusgabe:
NAME READY STATUS RESTARTS AGE details-v1-1520924117-48z17 2/2 Running 0 6m productpage-v1-560495357-jk1lz 2/2 Running 0 6m ratings-v1-734492171-rnr5l 2/2 Running 0 6m reviews-v1-874083890-f0qf0 2/2 Running 0 6m reviews-v2-1343845940-b34q5 2/2 Running 0 6m reviews-v3-1813607990-8ch52 2/2 Running 0 6m
Definieren Sie abschließend das Ingress-Gateway-Routing für die Anwendung:
kubectl apply -f samples/bookinfo/networking/bookinfo-gateway.yamlAusgabe:
gateway.networking.istio.io/bookinfo-gateway created virtualservice.networking.istio.io/bookinfo created
Anwendungsbereitstellung validieren
Zum Prüfen, ob die BookInfo-Anwendung funktioniert, müssen Sie Traffic an das Ingress-Gateway senden.
Wenn Sie Cloud Service Mesh in Google Distributed Cloud installiert haben, rufen Sie die externe IP-Adresse des Ingress-Gateways ab, das Sie nach der Installation von Cloud Service Mesh konfiguriert haben.
Wenn Sie Cloud Service Mesh auf der GKE installiert haben, rufen Sie die externe IP-Adresse des Ingress-Gateways folgendermaßen ab:
kubectl get service istio-ingressgateway -n istio-systemAusgabe:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE istio-ingressgateway LoadBalancer 10.19.247.233 35.239.7.64 80:31380/TCP,443:31390/TCP,31400:31400/TCP 27m
In diesem Beispiel lautet die IP-Adresse des Ingress-Dienstes
35.239.7.64.
Anwendung testen
Prüfen Sie, ob die BookInfo-Anwendung mit
curlausgeführt wird:curl -I http://EXTERNAL_IP/productpageWenn die Antwort
200enthält, funktioniert die Anwendung fehlerfrei mit Cloud Service Mesh.Geben Sie die folgende Adresse in Ihren Browser ein, um die BookInfo-Webseite aufzurufen:
http://EXTERNAL_IP/productpageWenn Sie die Seite mehrmals aktualisieren, sollten auf der Produktseite verschiedene Versionen der Rezensionen in zufälliger Abfolge angezeigt werden (rote Sterne, schwarze Sterne, keine Sterne).
Da Ihre Anwendung jetzt Traffic generiert, können Sie die Cloud Service Mesh-Seiten in der Google Cloud Console aufrufen, um Messwerte und andere Beobachtbarkeitsfunktionen einzusehen.
Bereinigen
Wenn Sie mit dem Testen des Bookinfo-Beispiels fertig sind, entfernen Sie es aus Ihrem Cluster.
Deinstallieren Sie Bookinfo mit dem folgenden Skript:
samples/bookinfo/platform/kube/cleanup.shBestätigen Sie das Herunterfahren:
kubectl get virtualservices #-- there should be no virtual services kubectl get destinationrules #-- there should be no destination rules kubectl get gateway #-- there should be no gateway kubectl get pods #-- the Bookinfo pods should be deleted
Nächste Schritte
Weitere Informationen zum Bookinfo-Beispiel