Övning – Installera ett Helm-diagram
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 djurbutikapplikationen på ditt Kubernetes-kluster.
Distribuera ett Helm-diagram
Gå till Azure Cloud Shell- och kontrollera att du är i katalogen aks-store-demo. Annars ändrar du till katalogen med hjälp av
cd
.cd aks-store-demo
Byt till katalogen charts/aks-store-demo använd
cd
.cd charts
Distribuera Helm-schema för fronten av djuraffären med hjälp av kommandot
helm install
.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
Med Helm kan du köra frågor mot alla installerade versioner i klustret. Visa en lista över alla Helm-versioner med hjälp av 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
Med Helm kan du hämta manifestinformation som är relaterad till varje version. Hämta manifestinformation med hjälp av 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 ...
Kontrollera att podden har distribuerats med hjälp av 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 det är klart.
Ta bort en Helm-utgåva
Ta bort Helm-versionen med hjälp av 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 uppsättningsvä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.
Installera Helm-diagrammet med kommandot
helm install
med parametern--set
för att angereplicaCount
för distributionsmallen till fem repliker.helm install --set replicaCount=5 aks-store-demo ./aks-store-demo
Kontrollera att fem poddrepliker har distribuerats med hjälp av 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 det är klart.Ta bort Helm-diagrammet med hjälp av kommandot
helm delete
.helm delete aks-store-demo