使用Azure Portal,開發一個從GitHub持續佈署到Azure Container Apps的Web站台
程式碼簽入GitHub之後,啟動GitHub Action流程,編譯並部署程式到Azure Container Apps,是開發系統時常見的功能需求。本篇範例協助開發人員使用GitHub與Azure Portal,逐步完成必要的設計和實作。
範例下載:SleepZone.zip
操作步驟
1.註冊並登入Azure Portal。於首頁左上角的選單裡,點擊資源群組後,進入資源群組頁面。於資源群組頁面,點擊建立按鈕,依照頁面提示建立一個ResourceGroup,並命名為sleep-zone-group。
data:image/s3,"s3://crabby-images/cd032/cd03210098c4d5f67d6350e3b3dd4e004c400917" alt="01.建立ResourceGroup01.png"
data:image/s3,"s3://crabby-images/e7fd9/e7fd9bdb25e356dcb292adb35ca61ba7a08734f3" alt="01.建立ResourceGroup02.png"
data:image/s3,"s3://crabby-images/dc006/dc00651e675a229ab23f7f659d2051e0253ab127" alt="01.建立ResourceGroup03.png"
2.建立完畢後,於ResourceGroup頁面的屬性頁籤,取得「資源識別碼」。
data:image/s3,"s3://crabby-images/28d08/28d08f8fe9de929555de125b014377bbac25a788" alt="01.建立ResourceGroup04.png"
data:image/s3,"s3://crabby-images/4cbeb/4cbebcb75535b7982a48e378b7f156de855e99d5" alt="01.建立ResourceGroup05.png"
3.回到Azure Portal。於右上角的選單裡,點擊Cloud Shell按鈕後,開啟Cloud Shell視窗。於Cloud Shell視窗,切換至Bash並執行下列指令,用來取得部署使用的「服務主體憑證」。該指令會建立名為sleep-zone-app-contributor的應用程式註冊,並授權它為sleep-zone-group資源群組的參與者(Contributor)角色。
az ad sp create-for-rbac \
--name "sleep-zone-app-contributor" \
--role "Contributor" \
--scopes xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx \
--sdk-auth
- 服務主體名稱:--name "sleep-zone-app-contributor",可自訂,限制使用英文小寫與「-」。
- 服務主體授權角色:--role "Contributor"。
- 服務主體授權範圍:--scopes xxxxxxxxxxxxxxx。(xxxxx填入先前取得的資源識別碼)
data:image/s3,"s3://crabby-images/26f28/26f28d3a77994af2ffb8c8d4b616a21984f8018c" alt="02.建立Application01.png"
data:image/s3,"s3://crabby-images/e4996/e49966f9cf4bf63df3f4b02545dbb723f2eb56f6" alt="02.建立Application02.png"
4.回到Azure Portal。於首頁左上角的選單裡,點擊容器登錄後,進入容器登錄頁面。於容器登錄頁面,點擊建立按鈕,依照頁面提示建立一個ContainerRegistry,並命名為sleepzone。
data:image/s3,"s3://crabby-images/7cb39/7cb3960d651e60c236ddb4ac7e0cce325b76c86f" alt="03.建立ContainerRegistry01.png"
data:image/s3,"s3://crabby-images/eb784/eb784f41e9984b68a1478a323d15bc875cd95512" alt="03.建立ContainerRegistry02.png"
data:image/s3,"s3://crabby-images/5ad85/5ad855e754b18239074933292441f3ba3aff4d9c" alt="03.建立ContainerRegistry03.png"
5.建立完畢後,於ContainerRegistry頁面的存取金鑰頁籤,開啟「管理使用者」功能。
data:image/s3,"s3://crabby-images/9fc63/9fc6311edf76ac70a7c68c7eba56daa0c4a478e4" alt="03.建立ContainerRegistry04.png"
data:image/s3,"s3://crabby-images/2f987/2f9871e8ddc3f60c93dbb96dc7fa20d4e326d3f1" alt="03.建立ContainerRegistry05.png"
6.回到Azure Portal。於右上角的選單裡,點擊Cloud Shell按鈕後,開啟Cloud Shell視窗。於Cloud Shell視窗,切換至Bash並執行下列指令,用來佈署QuickStart映像檔到ContainerRegistry給後續流程使用。
az acr import \
--name sleepzone \
--source mcr.microsoft.com/k8se/quickstart:latest \
--image sleep-zone-app:latest
- 容器登錄名稱:--name sleepzone。(sleepzone為先前建立的容器登錄名稱)
- 來源映像名稱:--source mcr.microsoft.com/k8se/quickstart:latest,固定值。(微軟官方的QuickStart映像檔)
- 目的映像名稱:--image sleep-zone-app:latest,可自訂,格式為image-name:tag-name。(sleep-zone-app為容器應用名稱)
data:image/s3,"s3://crabby-images/a570f/a570f539dd395384bf59dcf0cbecf05a98a39665" alt="03.建立ContainerRegistry06.png"
7.回到Azure Portal。於首頁左上角的選單裡,點擊容器應用程式後,進入容器應用程式頁面。於容器應用程式頁面,點擊建立按鈕,依照頁面提示建立一個ContainerApp,命名為sleep-zone-app、並於容器頁簽設定使用先前建立的容器登錄、於輸入頁簽設定啟用輸入。
data:image/s3,"s3://crabby-images/73ffa/73ffa1022e2c8926ce7a2606b0a317da1b480253" alt="04.建立ContainerApp01.png"
data:image/s3,"s3://crabby-images/647f5/647f52c00226795919d6517312456468083bc5f5" alt="04.建立ContainerApp02.png"
data:image/s3,"s3://crabby-images/9abe4/9abe40617d069aab6be644dc47848207e78dde61" alt="04.建立ContainerApp03.png"
data:image/s3,"s3://crabby-images/18dbf/18dbff6c5f8652904c5e45f0e183d45c5ffabff5" alt="04.建立ContainerApp04.png"
data:image/s3,"s3://crabby-images/5feed/5feed798df73fd1845cca8fe33da7af5aaf82057" alt="04.建立ContainerApp05.png"
8.註冊並登入GitHub Dashboard。點擊首頁左上角的New按鈕,依照頁面提示建立一個Repository,並命名為SleepZone。
data:image/s3,"s3://crabby-images/353b6/353b6eb2d13ae4153fc3221a9aef16712f1fa399" alt="05.建立Repository01.png"
data:image/s3,"s3://crabby-images/4a9ab/4a9ab5dad0d245b204f9c22fd20c2934b973e116" alt="05.建立Repository02.png"
9.建立完畢後,於Repository頁面,點擊右上角的Setting按鈕進入Setting頁面,並選擇左側選單裡Secrets and variables的Action頁籤。於Action頁籤,點選New repository secret按鈕,依照頁面提示建立一個名為AZURE_CREDENTIALS的Actions Secret,Secret內容則是填入先前取得的「服務主體憑證」。
data:image/s3,"s3://crabby-images/35ab0/35ab08215c11f1e5464d45d4c0cefb80c862b1aa" alt="05.建立Repository03.png"
data:image/s3,"s3://crabby-images/5604a/5604a890f01b16f0deadc1a69ebc09a01aaf908f" alt="05.建立Repository04.png"
data:image/s3,"s3://crabby-images/129ec/129ecdca0fed12fdeff5c52c1debf0d8fe476f0f" alt="05.建立Repository05.png"
10.Clone SleepZone Repository到本機Repository資料夾,於本機Repository資料夾裡建立src資料夾。開啟命令提示字元進入src資料夾,輸入下列指令,用以安裝MDP.WebApp範本、並且建立一個名為WebApplication1的Web站台。
// 建立Web站台
dotnet new install MDP.WebApp
dotnet new MDP.WebApp -n WebApplication1
data:image/s3,"s3://crabby-images/7967b/7967b4855d9335da9bf27659205987d7fbe2f2dc" alt="06.建立WebApplication01.png"
data:image/s3,"s3://crabby-images/3a2a4/3a2a4a67f090de6f77bb37e1f12741d536294571" alt="06.建立WebApplication02.png"
11.於本機Repository資料夾裡,進入src/WebApplication1資料夾,並加入Dockerfile。
FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443
FROM mcr.microsoft.com/dotnet/sdk:7.0 AS build
WORKDIR /repo
COPY . .
RUN dotnet publish "src/WebApplication1/WebApplication1.csproj" -c Release -o /app/publish /p:UseAppHost=false
FROM base AS final
WORKDIR /app
COPY --from=build /app/publish .
ENTRYPOINT ["dotnet", "WebApplication1.dll"]
data:image/s3,"s3://crabby-images/373b6/373b670f794d2dbb1749a0b9d5cc4c5c5af07a0d" alt="06.建立WebApplication03.png"
12.於本機Repository資料夾裡,建立.github\workflows資料夾,並加入azure-build-deployment.yml。
// azure-build-deployment.yml
name: azure-build-deployment
on:
push:
branches:
- main
env:
RESOURCE_GROUP_NAME: sleep-zone-group
CONTAINER_APPS_NAME: sleep-zone-app
CONTAINER_REGISTRY_NAME: sleepzone
DOCKER_FILE_PATH: ./src/WebApplication1/Dockerfile
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Login Azure CLI
uses: azure/login@v1
with:
creds: ${{ secrets.AZURE_CREDENTIALS }}
- name: Checkout GitHub Repository
uses: actions/checkout@v4
- name: Deploy ContainerRegistry
uses: azure/CLI@v1
with:
inlineScript: >-
az acr build
--registry ${{ env.CONTAINER_REGISTRY_NAME }}
--file ${{ env.DOCKER_FILE_PATH }}
--image ${{ env.CONTAINER_APPS_NAME }}:${{ github.sha }} .
- name: Deploy ContainerApp
uses: azure/CLI@v1
with:
inlineScript: >-
az containerapp update
--name ${{ env.CONTAINER_APPS_NAME }}
--resource-group ${{ env.RESOURCE_GROUP_NAME }}
--image ${{ env.CONTAINER_REGISTRY_NAME }}.azurecr.io/${{ env.CONTAINER_APPS_NAME }}:${{ github.sha }}
- Git分支名稱:main,要特別注意Repository裡的分支是 master or main。
- 資源群組名稱:RESOURCE_GROUP_NAME: sleep-zone-group,可自訂,限制使用英文小寫與「-」。
- 容器應用名稱:CONTAINER_APPS_NAME: sleep-zone-app,可自訂,限制使用英文小寫與「-」。
- 容器登錄名稱:CONTAINER_REGISTRY_NAME: sleepzone,可自訂,限制使用英文小寫。
- Dockerfile路徑:DOCKER_FILE_PATH: ./src/WebApplication1/Dockerfile,路徑區分大小寫,相對於Repository資料夾。
data:image/s3,"s3://crabby-images/44389/44389441db69d1650d022f0cd3bbaf6a49a8c327" alt="06.建立WebApplication04.png"
13.簽入並推送本機Repository的變更,到遠端GitHub主機之後。回到GitHub Dashboard,進入SleepZone Repository頁面。可以於Actions頁籤裡,可以看到GitHub Action流程已經觸發執行並成功完成部署。(需時約兩分鐘)
data:image/s3,"s3://crabby-images/0385a/0385a6ad5fc4de4fc6cc743ec2d69e644e706ae1" alt="07.執行結果01.png"
14.回到Azure Portal。於首頁左上角的選單裡,點擊容器應用程式後,進入容器應用程式頁面。於ContainerApp頁面的概觀頁籤,點擊「應用程式 URL」鏈結,在開啟的Browser視窗內,可以看到由WebApplication1程式碼所提供的Hello World。
data:image/s3,"s3://crabby-images/cdca8/cdca8ec9b37fdd5f2aed928fe5cc455132d9c25e" alt="07.執行結果02.png"
data:image/s3,"s3://crabby-images/c81dd/c81ddd7f36e812cc71e0469fe1a27d5d3aae6079" alt="07.執行結果03.png"
data:image/s3,"s3://crabby-images/63b1e/63b1e7b03537bd570775db9db77a7c59bc45e4df" alt="07.執行結果04.png"
15.完成上述步驟之後,每次推送程式碼到GitHub,都會啟動GitHub Action流程,編譯並部署程式到Azure Container Apps。
data:image/s3,"s3://crabby-images/2b5ef/2b5eff67481f79d2a87fd7c5cdc99c0a7f2b790d" alt="07.執行結果05.png"
能以更簡潔的文字與程式碼,傳達出程式設計背後的精神。
真正做到「以形寫神」的境界。