Übung: Installieren eines Helm-Charts

Abgeschlossen

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

  1. 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
    
  2. Wechseln Sie in das charts/aks-store-demo-Verzeichnis mithilfe von cd.

    cd charts
    
  3. 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
    
  4. 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
    
  5. 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
    ...
    
  6. Ü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

  1. 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.

  1. Installieren Sie das Helm-Diagramm mithilfe des Befehls helm install mit dem Parameter --set, um die replicaCount der Bereitstellungsvorlage auf fünf Replikate festzulegen.

    helm install --set replicaCount=5 aks-store-demo ./aks-store-demo
    
  2. Ü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.

  3. Löschen Sie das Helm-Chart mit dem Befehl helm delete.

    helm delete aks-store-demo