Övning – Installera ett Helm-diagram

Slutförd

Helm-diagram gör det enkelt att installera förkonfigurerade molnbaserade appar i ett Kubernetes-kluster.

I den här övningen ska du använda Helm för att installera programmet för djurlager i Kubernetes-klustret.

Distribuera ett Helm-diagram

  1. Gå till Azure Cloud Shell och kontrollera att du är i katalogen aks-store-demo . Annars ändrar du till katalogen med .cd

    cd aks-store-demo
    
  2. Ändra till katalogen charts/aks-store-demo med hjälp av cd.

    cd charts
    cd aks-store-demo
    
  3. Distribuera helm-diagrammet för djurlagrets front med hjälp av helm install kommandot .

    helm install aks-store-demo ./aks-store-demo
    

    Kommandot bör returnera ett resultat som liknar följande utdata:

    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. Med Helm kan du fråga i alla installerade versioner i klustret. Visa en lista över alla Helm-versioner med kommandot helm list .

    helm list
    

    Kommandot bör returnera ett resultat som liknar följande utdata:

    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. Med Helm kan du hämta manifestinformation som är relaterad till varje version. Hämta manifestinformation med kommandot helm get manifest .

    helm get manifest aks-store-demo
    

    Kommandot bör returnera ett resultat som liknar följande komprimerade utdata:

    ---
    # 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. Kontrollera att podden har distribuerats med kommandot kubectl get pods .

    kubectl get pods -o wide -w
    

    Kommandot bör returnera ett resultat som liknar följande utdata:

    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>
    

    Använd Ctrl+C för att avsluta kommandot när du är färdig.

Ta bort en Helm-version

  1. Ta bort Helm-versionen med kommandot helm delete .

    helm delete aks-store-demo
    

    Kommandot bör returnera ett resultat som liknar följande utdata:

    release "aks-store-demo" uninstalled
    

Installera ett Helm-diagram med set-värden

Du kan åsidosätta värden för ett Helm-diagram genom att skicka antingen en värdeparameter eller en egen values.yaml fil. För tillfället använder du följande kommandon för att se hur du uppdaterar ett värde med hjälp av parametern --set . Du får lära dig hur du använder en values.yaml fil i nästa lektion.

  1. Installera Helm-diagrammet med helm install kommandot med parametern --set för att ange replicaCount distributionsmallen till fem repliker.

    helm install --set replicaCount=5 aks-store-demo ./aks-store-demo
    
  2. Kontrollera att fem poddrepliker har distribuerats med kommandot kubectl get pods .

    kubectl get pods -o wide -w
    

    Kommandot bör returnera ett resultat som liknar följande utdata:

    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>
    

    Använd Ctrl+C för att avsluta kommandot när du är färdig.

  3. Ta bort Helm-diagrammet med kommandot helm delete .

    helm delete aks-store-demo