Share via


Egyéni tároló üzembe helyezése Azure-alkalmazás szolgáltatásban az Azure Pipelines használatával

Azure DevOps Services | Azure DevOps Server 2022 – Azure DevOps Server 2019

Az Azure Pipelines használatával létrehozhatja, tesztelheti és automatikusan üzembe helyezheti a webalkalmazást egy Azure-alkalmazás Service Web App-tárolóban Linuxon. Ebből a cikkből megtudhatja, hogyan használhatja a YAML-et vagy a klasszikus folyamatokat a következőre:

  • Docker-rendszerkép létrehozása és közzététele az Azure Container Registryben
  • Azure-webalkalmazás létrehozása
  • Tároló üzembe helyezése Azure-alkalmazás szolgáltatásban
  • Üzembe helyezés üzembehelyezési pontokon

Előfeltételek

A kód letöltése

Fork a következő mintaalkalmazást a GitHubon.

https://github.com/spring-guides/gs-spring-boot-docker.git

Docker-rendszerkép létrehozása és közzététele az Azure Container Registryben

A szakasz sikeres elvégzéséhez rendelkeznie kell egy Azure Container Registry-beállításjegyzékel. A részletekért tekintse meg az előfeltételek szakaszt.

  1. Jelentkezzen be az Azure DevOps-szervezetbe, és lépjen a projekthez.

  2. Válassza a Folyamatok, majd az Új folyamat lehetőséget.

  3. Válassza a GitHubot , amikor a rendszer kéri a forráskód helyét, majd válassza ki az adattárat.

  4. Válassza ki a Dockert: hozzon létre és küldjön le egy lemezképet az Azure Container Registry-folyamatsablonba .

    Docker-folyamatsablon kiválasztása

  5. Válassza ki az Azure-előfizetését, majd válassza a Folytatás lehetőséget.

  6. Válassza ki a Tárolóregisztrációs adatbázist a legördülő menüből, majd válassza az Ellenőrzés és konfigurálás lehetőséget.

    A Docker ellenőrzése és konfigurálása

  7. Tekintse át a folyamat YAML-sablonját, majd válassza a Mentés és futtatás lehetőséget a Docker-rendszerkép létrehozásához és közzétételéhez az Azure Container Registryben.

    trigger:
    - main
    
    resources:
    - repo: self
    
    variables:
        # Container registry service connection established during pipeline creation
        dockerRegistryServiceConnection: '{{ containerRegistryConnection.Id }}'
        imageRepository: 'javascriptdocker'
        containerRegistry: 'sampleappcontainerregistry.azurecr.io'
        dockerfilePath: '$(Build.SourcesDirectory)/app/Dockerfile'
        tag: '$(Build.BuildId)'
    
        # Agent VM image name
        vmImageName: 'ubuntu-latest'
    
    stages:
    - stage: Build
        displayName: Build and push stage
        jobs:
        - job: Build
        displayName: Build
        pool:
            vmImage: $(vmImageName)
        steps:
        - task: Docker@2
            displayName: Build and push an image to container registry
            inputs:
            command: buildAndPush
            repository: $(imageRepository)
            dockerfile: $(dockerfilePath)
            containerRegistry: $(dockerRegistryServiceConnection)
            tags: |
                $(tag)
    
  8. Ha meg szeretné tekinteni a közzétett Docker-rendszerképet a folyamatfuttatás befejezése után, keresse meg a tárolóregisztrációs adatbázist az Azure Portalon, majd válassza az Adattárak lehetőséget.

    Az Azure Container Registryben közzétett Docker-rendszerkép

  9. Ha a rendszerképet a tárolóregisztrációs adatbázisból szeretné üzembe helyezni, engedélyeznie kell a rendszergazdai felhasználói fiókot. Lépjen a tárolóregisztrációs adatbázisra az Azure Portalon, és válassza az Access-kulcsokat. Ezután válassza a váltógombot Rendszergazda felhasználó engedélyezéséhez.

    Rendszergazda felhasználó engedélyezése

Webalkalmazás létrehozása

  1. Nyissa meg az Azure Portalt.

  2. Válassza az Erőforrástárolók> létrehozása, majd a Web App for Containers lehetőséget.

    Webalkalmazás létrehozása tárolóerőforráshoz

  3. Adja meg az új webalkalmazás nevét, és hozzon létre egy új erőforráscsoportot. Válassza a Linuxot az operációs rendszerhez.

    A webalkalmazás konfigurálása

  4. A Tarifacsomagok szakaszban válassza az F1 Ingyenes csomagot.

  5. Válassza a Véleményezés és létrehozás lehetőséget. Tekintse át a konfigurációt, és válassza a Létrehozás lehetőséget, ha elkészült.

Üzembe helyezés a Web App for Containersben

Ebben a YAML-ben létrehoz és leküld egy Docker-lemezképet egy tárolóregisztrációs adatbázisba, majd üzembe helyezi azt az Azure Web App for Containersben. A buildelési szakaszban docker-rendszerképet hozhat létre és küldhet le egy Azure Container Registrybe a Docker@2 feladattal. A AzureWebAppContainer@1 feladat üzembe helyezi a lemezképet a Web App for Containersben.


trigger:
- main

resources:
- repo: self

variables: 
  ## Add this under variables section in the pipeline
  azureSubscription: <Name of the Azure subscription>
  appName: <Name of the Web App>
  containerRegistry: <Name of the Azure container registry>
  dockerRegistryServiceConnection: '4fa4efbc-59af-4c0b-8637-1d5bf7f268fc'
  imageRepository: <Name of image repository>
  dockerfilePath: '$(Build.SourcesDirectory)/Dockerfile'
  tag: '$(Build.BuildId)'

  vmImageName: 'ubuntu-latest'

stages:
- stage: Build
  displayName: Build and push stage
  jobs:
  - job: Build
    displayName: Build
    pool:
      vmImage: $(vmImageName)
    steps:
    - task: Docker@2
      displayName: Build and push an image to container registry
      inputs:
        command: buildAndPush
        repository: $(imageRepository)
        dockerfile: $(dockerfilePath)
        containerRegistry: $(dockerRegistryServiceConnection)
        tags: |
          $(tag)


    ## Add the below snippet at the end of your pipeline
    - task: AzureWebAppContainer@1
      displayName: 'Azure Web App on Container Deploy'
      inputs:
        azureSubscription: $(azureSubscription)
        appName: $(appName)
        containers: $(containerRegistry)/$(imageRepository):$(tag)

Üzembe helyezés üzembe helyezési ponton

Az Azure Web App-tárolót több tárolóhelyre is konfigurálhatja. A pontok lehetővé teszik az alkalmazás biztonságos üzembe helyezését és tesztelését, mielőtt elérhetővé tenné az ügyfelek számára. További részletekért lásd : Előkészítési környezetek létrehozása.

Az alábbi YAML-kódrészlet bemutatja, hogyan lehet üzembe helyezni egy előkészítési ponton, majd felcserélni egy éles pontra:

- task: AzureWebAppContainer@1
  inputs:
    azureSubscription: '<Azure service connection>'
    appName: '<Name of the web app>'
    containers: $(containerRegistry)/$(imageRepository):$(tag)
    deployToSlotOrASE: true
    resourceGroupName: '<Name of the resource group>'
    slotName: staging

- task: AzureAppServiceManage@0
  inputs:
    azureSubscription: '<Azure service connection>'
    WebAppName: '<name of web app>'
    ResourceGroupName: '<name of resource group>'
    SourceSlot: staging
    SwapWithProduction: true

GYIK

K: Hogyan találom meg a Docker-beállításjegyzék hitelesítő adatait?

Válasz: Lépjen az Azure Portalra, és válassza ki a Web App for Containers alkalmazást. Válassza a Konfigurációs>alkalmazás beállításait, majd kattintson az érték megjelenítéséhez.

Képernyőkép a Docker-beállításjegyzék hitelesítő adatainak megkereséséről.