Wdrażanie obrazu kontenera w usłudze Azure Kubernetes Service

Ukończone

W tej lekcji wdrożysz obraz kontenera w usłudze Azure Kubernetes Service.

Za pomocą usługi Azure Kubernetes Service skonfigurujesz klaster Kubernetes do uruchamiania w żądanym stanie za pomocą Deployment, który jest procesem dostarczania deklaratywnych aktualizacji dla Pods i ReplicaSets. Ta deklaracja stanu jest zarządzana w pliku manifestu (YAML), a kontroler Kubernetes zmieni bieżący stan na zadeklarowany, gdy otrzyma instrukcję. Utworzysz ten plik manifestu deployment.yml i poinstruujesz usługę Azure Kubernetes Service, aby działała w żądanym stanie z zasobnikami skonfigurowanymi do pobierania/uruchamiania obrazu kontenera flightbookingsystemsample znajdującego się w usłudze Azure Container Registry, który przesunęliśmy w poprzedniej jednostce. Bez tego pliku manifestu musiałbyś ręcznie tworzyć, aktualizować i usuwać pody zamiast pozwolić, by Kubernetes orkiestruje proces.

Notatka

Jeśli sesja uległa bezczynności lub wykonujesz ten krok w innym momencie i/lub z innego interfejsu wiersza polecenia, może być konieczne ponowne zainicjowanie zmiennych środowiskowych i ponowne uwierzytelnienie przy użyciu następujących poleceń interfejsu wiersza polecenia.

AZ_RESOURCE_GROUP=javacontainerizationdemorg

AZ_CONTAINER_REGISTRY=<YOUR_CONTAINER_REGISTRY>

AZ_KUBERNETES_CLUSTER=javacontainerizationdemoaks

AZ_LOCATION=<YOUR_AZURE_REGION>

AZ_KUBERNETES_CLUSTER_DNS_PREFIX=<TWÓJ_UNIKALNY_DNS_PREFIX_DO_DOSTĘPU_DO_TWOJEGO_AKS_CLUSTER>

az login

az acr login -n $AZ_CONTAINER_REGISTRY

Wdrażanie obrazu kontenera

W tym miejscu wdrożysz obraz kontenera flightbookingsystemsample w klastrze usługi Azure Kubernetes.

W katalogu głównym swojego projektu, Flight-Booking-System-JavaServlets_App/Project/Airlines, utwórz plik o nazwie deployment.yml. Uruchom następujące polecenie w konsoli.

vi deployment.yml

Dodaj następującą zawartość do deployment.yml, a następnie zapisz i zamknij:

Notatka

Zaktualizuj wartość zmiennej środowiskowej AZ_CONTAINER_REGISTRY ustawioną wcześniej; na przykład javacontainerizationdemoacr.

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

Notatka

Opcjonalnie plik deployment_solution.yml w katalogu głównym projektu zawiera wymaganą zawartość; Możesz łatwiej zmienić nazwę/zaktualizować zawartość tego pliku.

W poprzednim deployment.ymlzauważysz, że plik zawiera wdrożenie i usługę. Wdrożenie służy do administrowania zestawem zasobników, a usługa służy do zezwalania na dostęp sieciowy do zasobników. Zauważysz, że zasobniki są skonfigurowane do pobierania pojedynczego obrazu <AZ_CONTAINER_REGISTRY>.azurecr.io/flightbookingsystemsample:latest z Azure Container Registry. Zauważysz również, że usługa jest skonfigurowana tak, aby zezwalała na przychodzący ruch zasobników HTTP do portu 8080, podobnie jak w przypadku lokalnego uruchomienia obrazu kontenera z argumentem portu -p.

Do tej pory tworzenie klastra Azure Kubernetes zakończyło się pomyślnie.

Będziesz chciał skonfigurować Azure CLI, aby uzyskać dostęp do klastra Usługi Azure Kubernetes za pomocą polecenia kubectl. Zainstaluj narzędzie kubectl lokalnie przy użyciu polecenia az aks install-cli. Uruchom następujące polecenie w interfejsie wiersza polecenia:

az aks install-cli

Skonfiguruj narzędzie kubectl, aby nawiązać połączenie z klastrem Kubernetes przy użyciu polecenia az aks get-credentials. Uruchom następujące polecenie w interfejsie wiersza polecenia:

az aks get-credentials --resource-group $AZ_RESOURCE_GROUP --name $AZ_KUBERNETES_CLUSTER

Zostaną wyświetlone dane wyjściowe podobne do następujących:

Merged AZ_KUBERNETES_CLUSTER as current context in ~/.kube/config

Teraz poinstruujesz usługę Azure Kubernetes Service, aby zastosować zmiany z pliku deployment.yml w klastrze. Uruchom następujące polecenie w konsoli.

kubectl apply -f deployment.yml

Zostaną wyświetlone dane wyjściowe podobne do następujących:

deployment.apps/flightbookingsystemsample created
service/flightbookingsystemsample created

Teraz możesz użyć kubectl do monitorowania stanu wdrożenia. Uruchom następujące polecenie w konsoli:

kubectl get all

Zostaną wyświetlone dane wyjściowe podobne do następujących:

NAME                                   READY   STATUS    RESTARTS   AGE
pod/flightbookingsystemsample-75647c4c98-v4v4r   1/1     Running   2          13d

NAME                      TYPE           CLUSTER-IP    EXTERNAL-IP    PORT(S)          AGE
service/kubernetes        ClusterIP      10.0.0.1      <none>         443/TCP          66d
service/flightbookingsystemsample   LoadBalancer   10.0.34.128   20.81.13.151   8080:30265/TCP   66d

NAME                              READY   UP-TO-DATE   AVAILABLE   AGE
deployment.apps/flightbookingsystemsample   1/1     1            1           66d

NAME                                         DESIRED   CURRENT   READY   AGE
replicaset.apps/flightbookingsystemsample-75647c4c98   1         1         1       66d
replicaset.apps/flightbookingsystemsample-7564c58f55   0         0         0       13d

Jeśli stan POD to Running, aplikacja powinna być dostępna.

Logi aplikacji można również wyświetlić w każdym podzie. Uruchom następujące polecenie w CLI:

 kubectl logs pod/flightbookingsystemsample-<POD_IDENTIFIER_FROM_YOUR_RUNNING_POD>

Zostaną wyświetlone dane wyjściowe podobne do następujących:

NOTE: Picked up JDK_JAVA_OPTIONS:  --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
07-Oct-2021 18:31:14.073 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server version name:   Apache Tomcat/8.5.71
07-Oct-2021 18:31:14.164 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server built:          Sep 9 2021 18:43:14 UTC
07-Oct-2021 18:31:14.164 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Server version number: 8.5.71.0
07-Oct-2021 18:31:14.165 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Name:               Linux
07-Oct-2021 18:31:14.166 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log OS Version:            5.4.0-1051-azure
07-Oct-2021 18:31:14.166 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Architecture:          amd64
07-Oct-2021 18:31:14.166 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Java Home:             /usr/local/openjdk-11
07-Oct-2021 18:31:14.167 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Version:           11.0.12+7
07-Oct-2021 18:31:14.167 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log JVM Vendor:            Oracle Corporation
07-Oct-2021 18:31:14.167 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_BASE:         /usr/local/tomcat
07-Oct-2021 18:31:14.168 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log CATALINA_HOME:         /usr/local/tomcat
07-Oct-2021 18:31:14.261 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.lang=ALL-UNNAMED
07-Oct-2021 18:31:14.261 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.io=ALL-UNNAMED
07-Oct-2021 18:31:14.261 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.util=ALL-UNNAMED
07-Oct-2021 18:31:14.262 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.base/java.util.concurrent=ALL-UNNAMED
07-Oct-2021 18:31:14.262 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
07-Oct-2021 18:31:14.262 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties
07-Oct-2021 18:31:14.263 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
07-Oct-2021 18:31:14.263 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djdk.tls.ephemeralDHKeySize=2048
07-Oct-2021 18:31:14.263 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.protocol.handler.pkgs=org.apache.catalina.webresources
07-Oct-2021 18:31:14.263 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dorg.apache.catalina.security.SecurityListener.UMASK=0027
07-Oct-2021 18:31:14.264 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dignore.endorsed.dirs=
07-Oct-2021 18:31:14.264 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.base=/usr/local/tomcat
07-Oct-2021 18:31:14.264 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.home=/usr/local/tomcat
07-Oct-2021 18:31:14.265 INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Djava.io.tmpdir=/usr/local/tomcat/temp
07-Oct-2021 18:31:14.265 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent Loaded Apache Tomcat Native library [1.2.31] using APR version [1.7.0].
07-Oct-2021 18:31:14.265 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent APR capabilities: IPv6 [true], sendfile [true], accept filters [false], random [true], UDS [{4}].
07-Oct-2021 18:31:14.266 INFO [main] org.apache.catalina.core.AprLifecycleListener.lifecycleEvent APR/OpenSSL configuration: useAprConnector [false], useOpenSSL [true]
07-Oct-2021 18:31:14.361 INFO [main] org.apache.catalina.core.AprLifecycleListener.initializeSSL OpenSSL successfully initialized [OpenSSL 1.1.1k  25 Mar 2021]
07-Oct-2021 18:31:14.763 INFO [main] org.apache.coyote.AbstractProtocol.init Initializing ProtocolHandler ["http-nio-8080"]
07-Oct-2021 18:31:14.962 INFO [main] org.apache.tomcat.util.net.NioSelectorPool.getSharedSelector Using a shared selector for servlet write/read
07-Oct-2021 18:31:15.071 INFO [main] org.apache.catalina.startup.Catalina.load Initialization processed in 6497 ms
07-Oct-2021 18:31:15.771 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina]
07-Oct-2021 18:31:15.772 INFO [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet engine: [Apache Tomcat/8.5.71]
07-Oct-2021 18:31:16.261 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deploying web app archive [/usr/local/tomcat/webapps/FlightBookingSystemSample.war]
07-Oct-2021 18:31:30.782 INFO [localhost-startStop-1] 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.
WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by com.sun.xml.ws.policy.privateutil.MethodUtil (file:/usr/local/tomcat/webapps/FlightBookingSystemSample/WEB-INF/lib/webservices-rt-2.3.1.jar) to method sun.reflect.misc.MethodUtil.invoke(java.lang.reflect.Method,java.lang.Object,java.lang.Object[])
WARNING: Please consider reporting this to the maintainers of com.sun.xml.ws.policy.privateutil.MethodUtil
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release
07-Oct-2021 18:31:53.370 INFO [localhost-startStop-1] com.sun.xml.ws.server.MonitorBase.createRoot Metro monitoring rootname successfully set to: com.sun.metro:pp=/,type=WSEndpoint,name=/FlightBookingSystemSample-PriceAndSeats-PriceAndSeatsPort
07-Oct-2021 18:31:54.864 INFO [localhost-startStop-1] com.sun.xml.ws.transport.http.servlet.WSServletDelegate.<init> WSSERVLET14: JAX-WS servlet initializing
07-Oct-2021 18:32:02.869 INFO [localhost-startStop-1] com.sun.xml.ws.transport.http.servlet.WSServletContextListener.contextInitialized WSSERVLET12: JAX-WS context listener initializing
07-Oct-2021 18:32:02.870 INFO [localhost-startStop-1] com.sun.xml.ws.transport.http.servlet.WSServletContextListener.contextInitialized WSSERVLET12: JAX-WS context listener initializing
07-Oct-2021 18:32:03.069 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deployment of web app archive [/usr/local/tomcat/webapps/FlightBookingSystemSample.war] has finished in [46,808] ms
07-Oct-2021 18:32:03.165 INFO [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["http-nio-8080"]
07-Oct-2021 18:32:03.267 INFO [main] org.apache.catalina.startup.Catalina.start Server startup in 48195 ms

Teraz możesz użyć EXTERNAL-IP z danych wyjściowych kubectl get services flightbookingsystemsample, aby uzyskać dostęp do aplikacji działającej w usłudze Azure Kubernetes Service.

Notatka

Zastąp adres IP (20.81.13.151) adresem IP Twojego EXTERNAL-IP uzyskanym z wcześniej wykonanego polecenia.

Otwórz przeglądarkę i odwiedź stronę docelową Flight Booking System Sample pod adresem http://20.81.13.151:8080/FlightBookingSystemSample

Zostanie wyświetlona strona podobna do tej:

Zrzut ekranu przedstawiający uruchomioną aplikację.

Opcjonalnie możesz zalogować się za pomocą dowolnego użytkownika z tomcat-users.xml; na przykład someuser@azure.com: password.