Bereitstellen des Containerimages in Azure Kubernetes Service
In dieser Lektion stellen Sie ein Containerimage für Azure Kubernetes Service (AKS) bereit. Mit AKS konfigurieren Sie Ihren Kubernetes-Cluster so, dass er über eine Bereitstellung in einem gewünschten Zustand ausgeführt wird. Dabei handelt es sich um die Bereitstellung deklarativer Updates für Pods und ReplicaSets. Diese Deklaration des Zustands wird in der YAML-Manifestdatei verwaltet, und der Kubernetes-Controller ändert den aktuellen Zustand in den deklarierten Zustand, wenn er angewiesen wird. Sie erstellen diese deployment.yml Manifestdatei und weisen Ihre AKS-Instanz an, in einem gewünschten Zustand mit konfigurierten Pods zu laufen, die so eingerichtet sind, dass sie das flightbookingsystemsample Containerimage aus der Azure-Containerregistrierung abrufen und ausführen, das Sie in der vorherigen Einheit hochgeladen haben. Ohne diese Manifestdatei müssen Sie Pods manuell erstellen, aktualisieren und löschen, anstatt Kubernetes den Prozess orchestrieren zu lassen.
Hinweis
Wenn Ihre Sitzung sich im Leerlauf befindet oder Sie diesen Schritt zu einem anderen Zeitpunkt oder von einer anderen CLI ausführen, müssen Sie ihre Umgebungsvariablen möglicherweise erneut initialisieren und erneut authentifizieren, indem Sie die folgenden Befehle verwenden:
export AZ_RESOURCE_GROUP=java-containerization-demo-rg
export AZ_CONTAINER_REGISTRY=<your-container-registry>
export AZ_KUBERNETES_CLUSTER=java-containerization-demo-aks
export AZ_LOCATION=<your-Azure-region>
export AZ_KUBERNETES_CLUSTER_DNS_PREFIX=<your-unique-DNS-prefix-to-access-your-AKS-cluster>
az login
az acr login --name $AZ_CONTAINER_REGISTRY
Bereitstellen eines Containerimages
Nun stellen Sie das Containerimage flightbookingsystemsample in Ihrem AKS-Cluster bereit. Erstellen Sie im Stammordner Ihres Projekts eine Datei namens deployment.yml mit dem folgenden Befehl: "Flight-Booking-System-JavaServlets_App/Project/Airlines":
vi deployment.yml
Fügen Sie den folgenden Inhalt zu deployment.yml hinzu, speichern Sie die Datei und beenden Sie den Vorgang. Achten Sie darauf, den <AZ_CONTAINER_REGISTRY> Platzhalter durch den Wert der AZ_CONTAINER_REGISTRY Umgebungsvariablen zu ersetzen, den Sie zuvor festgelegt haben. Zum Speichern und Beenden drücken Sie ESC, geben Sie :wq! ein, und drücken Sie dann die EINGABETASTE.
apiVersion: apps/v1
kind: Deployment
metadata:
name: flightbookingsystemsample
spec:
replicas: 1
selector:
matchLabels:
app: flightbookingsystemsample
template:
metadata:
labels:
app: flightbookingsystemsample
spec:
containers:
- name: flightbookingsystemsample
image: <AZ_CONTAINER_REGISTRY>.azurecr.io/flightbookingsystemsample:latest
resources:
requests:
cpu: "1"
memory: "1Gi"
limits:
cpu: "2"
memory: "2Gi"
ports:
- containerPort: 8080
---
apiVersion: v1
kind: Service
metadata:
name: flightbookingsystemsample
spec:
type: LoadBalancer
ports:
- port: 8080
targetPort: 8080
selector:
app: flightbookingsystemsample
Hinweis
Optional können Sie die deployment_solution.yml Datei im Stammordner Ihres Projekts verwenden, die die benötigten Inhalte enthält. Möglicherweise ist es einfacher, den Inhalt dieser Datei umzubenennen oder zu aktualisieren.
Im vorherigen deployment.yml enthält die Datei eine Bereitstellung und einen Dienst. Die Bereitstellung wird verwendet, um eine Gruppe von Pods zu verwalten, und der Dienst wird verwendet, um den Netzwerkzugriff auf die Pods zu ermöglichen. Die Pods sind so konfiguriert, dass ein einzelnes Image, <AZ_CONTAINER_REGISTRY>.azurecr.io/flightbookingsystemsample:latest, aus der Azure-Containerregistrierung abgerufen wird. Der Dienst ist so konfiguriert, dass eingehender HTTP-Datenverkehr von Pods auf Port 8080 zugelassen wird, ähnlich wie Sie das Container-Image lokal mit dem -p-Portargument ausgeführt haben.
Wenn die Bereitstellung erfolgreich war, verfügen Sie jetzt über einen AKS-Cluster. Konfigurieren Sie Ihre Azure CLI für den Zugriff auf Ihren AKS-Cluster über den kubectl Befehl. Lokal mithilfe des folgenden Befehls installieren kubectl :
az aks install-cli
Konfigurieren Sie kubectl, um eine Verbindung mit Ihrem AKS-Cluster herzustellen, indem Sie den folgenden Befehl verwenden:
az aks get-credentials \
--resource-group $AZ_RESOURCE_GROUP \
--name $AZ_KUBERNETES_CLUSTER
Das folgende Ergebnis ist typisch:
Merged AZ_KUBERNETES_CLUSTER as current context in ~/.kube/config
Verwenden Sie AKS, um deployment.yml Änderungen auf Ihren Cluster anzuwenden, indem Sie den folgenden Befehl verwenden:
kubectl apply -f deployment.yml
Das folgende Ergebnis ist typisch:
deployment.apps/flightbookingsystemsample created
service/flightbookingsystemsample created
Überwachen Sie den Status der Bereitstellung mithilfe des folgenden Befehls:
kubectl get all
Das folgende Ergebnis ist typisch:
kubectl get all
NAME READY STATUS RESTARTS AGE
pod/flightbookingsystemsample-b7fd6684f-4j8vf 1/1 Running 0 37s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/flightbookingsystemsample LoadBalancer 10.0.62.153 <external-IP> 8080:30534/TCP 37s
service/kubernetes ClusterIP 10.0.0.1 <none> 443/TCP 11h
NAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/flightbookingsystemsample 1/1 1 1 37s
NAME DESIRED CURRENT READY AGE
replicaset.apps/flightbookingsystemsample-b7fd6684f 1 1 1 37s
Wenn Ihr POD Status lautet Running, sollte die App barrierefrei sein. Zeigen Sie die App-Protokolle in den einzelnen Pods mithilfe des folgenden Befehls an:
kubectl logs pod/flightbookingsystemsample-<pod-identifier-from-your-running-pod>
Das folgende Ergebnis ist typisch:
kubectl logs pod/flightbookingsystemsample-b7fd6684f-4j8vf
15-Nov-2024 12:31:51.208 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server version name: Apache Tomcat/10.1.33
15-Nov-2024 12:31:51.211 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server built: Nov 7 2024 22:28:55 UTC
15-Nov-2024 12:31:51.212 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server version number: 10.1.33.0
15-Nov-2024 12:31:51.212 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name: Linux
15-Nov-2024 12:31:51.212 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Version: 5.15.0-1074-azure
15-Nov-2024 12:31:51.212 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture: amd64
15-Nov-2024 12:31:51.216 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Java Home: /usr/lib/jvm/msopenjdk-17
15-Nov-2024 12:31:51.216 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Version: 17.0.13+11-LTS
15-Nov-2024 12:31:51.216 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Vendor: Microsoft
15-Nov-2024 12:31:51.216 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_BASE: /usr/local/tomcat
15-Nov-2024 12:31:51.216 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_HOME: /usr/local/tomcat
15-Nov-2024 12:31:51.226 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties
15-Nov-2024 12:31:51.226 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
15-Nov-2024 12:31:51.227 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djdk.tls.ephemeralDHKeySize=2048
15-Nov-2024 12:31:51.227 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.protocol.handler.pkgs=org.apache.catalina.webresources
15-Nov-2024 12:31:51.227 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dorg.apache.catalina.security.SecurityListener.UMASK=0027
15-Nov-2024 12:31:51.227 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.lang=ALL-UNNAMED
15-Nov-2024 12:31:51.228 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.io=ALL-UNNAMED
15-Nov-2024 12:31:51.228 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.util=ALL-UNNAMED
15-Nov-2024 12:31:51.228 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.util.concurrent=ALL-UNNAMED
15-Nov-2024 12:31:51.229 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
15-Nov-2024 12:31:51.229 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.base=/usr/local/tomcat
15-Nov-2024 12:31:51.229 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.home=/usr/local/tomcat
15-Nov-2024 12:31:51.229 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.io.tmpdir=/usr/local/tomcat/temp
15-Nov-2024 12:31:51.231 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent The Apache Tomcat Native library which allows using OpenSSL was not found on the java.library.path: [/usr/java/packages/lib:/usr/lib64:/lib64:/lib:/usr/lib]
15-Nov-2024 12:31:51.565 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["http-nio-8080"]
15-Nov-2024 12:31:51.602 INFO [main] org.apache.catalina.startup.Catalina.load Server initialization in [616] milliseconds
15-Nov-2024 12:31:51.658 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina]
15-Nov-2024 12:31:51.659 INFO [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet engine: [Apache Tomcat/10.1.33]
15-Nov-2024 12:31:51.689 INFO [main] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive [/usr/local/tomcat/webapps/AirlinesReservationSample.war]
15-Nov-2024 12:31:53.264 INFO [main] org.apache.jasper.servlet.TldScanner.scanJars At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time.
15-Nov-2024 12:31:55.155 INFO [main] com.sun.xml.ws.server.MonitorBase.createRoot Metro monitoring rootname successfully set to: com.sun.metro:pp=/,type=WSEndpoint,name=/AirlinesReservationSample-PriceAndSeats-PriceAndSeatsPort
15-Nov-2024 12:31:55.347 INFO [main] com.sun.xml.ws.transport.http.servlet.WSServletDelegate.<init> WSSERVLET14: XML-WS servlet initializing
WARNING:Error in the metadata of the table SEATS: table's row count in the metadata is 5 but 6 records have been found and loaded by UCanAccess. All will work fine, but it's better to repair your database.
15-Nov-2024 12:31:56.248 INFO [main] com.sun.xml.ws.transport.http.servlet.WSServletContextListener.contextInitialized WSSERVLET12: XML-WS context listener initializing
15-Nov-2024 12:31:56.249 INFO [main] com.sun.xml.ws.transport.http.servlet.WSServletContextListener.contextInitialized WSSERVLET12: XML-WS context listener initializing
15-Nov-2024 12:31:56.284 INFO [main] org.apache.catalina.startup.HostConfig.deployWAR Deployment of web application archive [/usr/local/tomcat/webapps/AirlinesReservationSample.war] has finished in [4,595] ms
15-Nov-2024 12:31:56.285 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/docs]
15-Nov-2024 12:31:56.315 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/docs] has finished in [30] ms
15-Nov-2024 12:31:56.316 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/examples]
15-Nov-2024 12:31:56.439 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/examples] has finished in [123] ms
15-Nov-2024 12:31:56.440 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/manager]
15-Nov-2024 12:31:56.456 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/manager] has finished in [16] ms
15-Nov-2024 12:31:56.457 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/ROOT]
15-Nov-2024 12:31:56.468 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/ROOT] has finished in [11] ms
15-Nov-2024 12:31:56.468 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/host-manager]
15-Nov-2024 12:31:56.481 INFO [main] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/host-manager] has finished in [13] ms
15-Nov-2024 12:31:56.484 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-8080"]
15-Nov-2024 12:31:56.501 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in [4897] milliseconds
Verwenden Sie EXTERNAL-IP aus der Ausgabe von kubectl get services flightbookingsystemsample, um in AKS auf die ausgeführte App zuzugreifen. Das folgende Ergebnis ist typisch:
kubectl get services flightbookingsystemsample
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
flightbookingsystemsample LoadBalancer 10.0.62.153 <external-IP> 8080:30534/TCP 3m28s
Hinweis
Ersetzen Sie die IP-Adresse <external-IP> in der folgenden URL durch Ihren EXTERNAL-IP Wert aus dem Befehl, den Sie zuvor ausgeführt haben:
Öffnen Sie einen Browser, und besuchen Sie die Startseite des Flight Booking System Sample unter http://<external-IP>:8080/AirlinesReservationSample/. Ihr Browser sollte dem folgenden Screenshot ähneln:
Sie können sich optional mit einem beliebigen Benutzerkonto von tomcat-users.xml anmelden, z. B. someuser@azure.com: password.
Bereinigen von Ressourcen
Die ressourcen, die Sie in diesem Modul erstellt haben, können laufende Kosten verursachen. Um die Ressourcen zu bereinigen, löschen Sie die Ressourcengruppe, die sie enthält, mithilfe des folgenden Befehls:
az group delete --name $AZ_RESOURCE_GROUP