Übung: Installieren eines Helm-Charts
Helm-Charts erleichtern die Installation von vorkonfigurierten cloudnativen Anwendungen in einem Kubernetes-Cluster.
In dieser Übung verwenden Sie Helm, um die Pet Store-Anwendung auf Ihrem Kubernetes-Cluster zu installieren.
Bereitstellen eines Helm-Charts
Navigieren Sie zu Azure Cloud Shell und stellen Sie sicher, dass Sie sich im aks-store-demo-Verzeichnis befinden. Wenn nicht, wechseln Sie mithilfe von
cd
in das Verzeichnis.cd aks-store-demo
Wechseln Sie in das charts/aks-store-demo-Verzeichnis mithilfe von
cd
.cd charts
Stellen Sie das Front-Helm-Diagramm des Pet Stores mithilfe des
helm install
-Befehls bereit.helm install aks-store-demo ./aks-store-demo
Mit dem Befehl sollte ein Ergebnis ähnlich der folgenden Ausgabe zurückgegeben werden:
NAME: aks-store-demo LAST DEPLOYED: Tue Feb 20 21:05:51 2024 NAMESPACE: default STATUS: deployed REVISION: 1 NOTES: 1. Get the application URL by running these commands: export POD_NAME=$(kubectl get pods --namespace default -l "app.kubernetes.io/name=aks-store-demo,app.kubernetes.io/instance=storedemo2" -o jsonpath="{.items[0].metadata.name}") export CONTAINER_PORT=$(kubectl get pod --namespace default $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}") echo "Visit http://127.0.0.1:8080 to use your application" kubectl --namespace default port-forward $POD_NAME 8080:$CONTAINER_PORT
Mit Helm können Sie alle im Cluster installierten Releases abfragen. Listen Sie alle Helm-Versionen mithilfe des
helm list
-Befehls auf.helm list
Mit dem Befehl sollte ein Ergebnis ähnlich der folgenden Ausgabe zurückgegeben werden:
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION aks-store-demo default 1 2024-02-20 21:05:51.557392349 +0000 UTC deployed aks-store-demo-0.1.0 1.16.0
Helm ermöglicht es Ihnen, Manifestinformationen zu den einzelnen Versionen abzurufen. Rufen Sie Manifestinformationen mithilfe des
helm get manifest
-Befehls ab.helm get manifest aks-store-demo
Der Befehl sollte ein Ergebnis wie die folgende komprimierte Ausgabe zurückgeben:
--- # Source: aks-store-demo-chart/templates/order-service.yaml apiVersion: v1 kind: Secret metadata: name: order-service-secret ... --- # Source: aks-store-demo-chart/templates/rabbitmq.yaml apiVersion: v1 kind: Secret metadata: name: rabbitmq-secret ... --- # Source: aks-store-demo-chart/templates/order-service.yaml apiVersion: v1 kind: ConfigMap metadata: name: makeline-service-configmap ...
Überprüfen Sie, ob der Pod mithilfe des Befehls
kubectl get pods
bereitgestellt wird.kubectl get pods -o wide -w
Mit dem Befehl sollte ein Ergebnis ähnlich der folgenden Ausgabe zurückgegeben werden:
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES makeline-service-8747ddb89-j6mvz 1/1 Running 0 6m11s 10.244.2.7 aks-nodepool1-41853373-vmss000001 <none> <none> mongodb-0 1/1 Running 0 6m11s 10.244.2.3 aks-nodepool1-41853373-vmss000001 <none> <none> order-service-7854888498-mlsvv 1/1 Running 0 6m11s 10.244.2.8 aks-nodepool1-41853373-vmss000001 <none> <none> product-service-5d7d4f5c47-gr4sc 1/1 Running 0 6m11s 10.244.2.6 aks-nodepool1-41853373-vmss000001 <none> <none> rabbitmq-0 1/1 Running 0 6m11s 10.244.2.2 aks-nodepool1-41853373-vmss000001 <none> <none> store-admin-894788d77-k5qjw 1/1 Running 0 6m11s 10.244.2.10 aks-nodepool1-41853373-vmss000001 <none> <none> store-front-6749d8579c-xdkv8 1/1 Running 0 6m11s 10.244.2.4 aks-nodepool1-41853373-vmss000001 <none> <none> virtual-customer-76c4bb9b7-dq6lc 1/1 Running 0 6m11s 10.244.2.9 aks-nodepool1-41853373-vmss000001 <none> <none> virtual-worker-56b79f9547-9dkm9 1/1 Running 0 6m11s 10.244.2.5 aks-nodepool1-41853373-vmss000001 <none> <none>
Verwenden Sie
Ctrl+C
, um den Befehl nach Abschluss zu beenden.
Löschen eines Helm-Releases
Löschen Sie die Helm-Version mit dem Befehl
helm delete
.helm delete aks-store-demo
Mit dem Befehl sollte ein Ergebnis ähnlich der folgenden Ausgabe zurückgegeben werden:
release "aks-store-demo" uninstalled
Installieren eines Helm-Charts mit festgelegten Werten
Werte für ein Helm-Chart können Sie außer Kraft setzen, indem Sie einen Wertparameter oder Ihre eigene values.yaml
-Datei übergeben. Verwenden Sie vorerst die folgenden Befehle, wenn Sie erfahren möchten, wie ein Wert mit dem Parameter --set
aktualisiert wird. Im nächsten Abschnitt erfahren Sie, wie Sie eine values.yaml
-Datei verwenden.
Installieren Sie das Helm-Diagramm mithilfe des Befehls
helm install
mit dem Parameter--set
, um diereplicaCount
der Bereitstellungsvorlage auf fünf Replikate festzulegen.helm install --set replicaCount=5 aks-store-demo ./aks-store-demo
Überprüfen Sie, ob fünf Podreplikate mithilfe des
kubectl get pods
-Befehls bereitgestellt wurden.kubectl get pods -o wide -w
Mit dem Befehl sollte ein Ergebnis ähnlich der folgenden Ausgabe zurückgegeben werden:
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES aks-store-demo-c8dfddf78-2v8fv 1/1 Running 0 31s 10.244.1.5 aks-nodepool1-41853373-vmss000000 <none> <none> aks-store-demo-c8dfddf78-8t4rq 1/1 Running 0 31s 10.244.2.16 aks-nodepool1-41853373-vmss000001 <none> <none> aks-store-demo-c8dfddf78-h2p8m 1/1 Running 0 31s 10.244.2.15 aks-nodepool1-41853373-vmss000001 <none> <none> aks-store-demo-c8dfddf78-l8qq2 1/1 Running 0 31s 10.244.0.10 aks-nodepool1-41853373-vmss000002 <none> <none> aks-store-demo-c8dfddf78-xwcpw 1/1 Running 0 31s 10.244.0.9 aks-nodepool1-41853373-vmss000002 <none> <none>
Verwenden Sie
Ctrl+C
, um den Befehl nach Abschluss zu beenden.Löschen Sie das Helm-Chart mit dem Befehl
helm delete
.helm delete aks-store-demo