Docker Registry settings
如何連到 Container Registry 並且使用它。
Azure Container Registry
從 ACR 設定中的存取金鑰取得登入伺服器、 username
和 password
。
data:image/s3,"s3://crabby-images/2bfcc/2bfcc9bf248045685ace0ab42986de3f944030b6" alt="azure-acr.png azure-acr.png"
打開設定中的 Docker 註冊表,選擇Docker V2
,並輸入登入伺服器、 username
和 password
。
data:image/s3,"s3://crabby-images/e7af4/e7af49025731cb928b68e688749976670458c9df" alt="acr.png acr.png"
也能從服務裡面新建設定
data:image/s3,"s3://crabby-images/697c4/697c4f52bafe7de2a7f8ebbf4e82b99d51c5d4c0" alt="service-bar.png service-bar.png"
選擇Docker V2
,並輸入 Azure Container Registry 的登入伺服器和帳號密碼
data:image/s3,"s3://crabby-images/41d11/41d110e4e282ecf1ae4b4b30adf93506e61ffabf" alt="acr-settings.png acr-settings.png"
推送
右鍵點擊 Dockerfile
data:image/s3,"s3://crabby-images/56bc1/56bc11e588c7874af564fb920767796b67ee5dd2" alt="dockerfile-right.png dockerfile-right.png"
運行或直接修改運行配置,鏡像標記中輸入一下名稱,方便以後識別,不然會是 sha256 (簡稱亂碼)
data:image/s3,"s3://crabby-images/cf2de/cf2dec25c6ce57c775b935c00603db2611623193" alt="dockerfile.png dockerfile.png"
運行後到服務 Docker 鏡像中會有剛剛的鏡像名稱的 image,右鍵可以推送鏡像
data:image/s3,"s3://crabby-images/08802/08802cfd9c60a37bad1144418aaa1beeea33a682" alt="images.png images.png"
選擇 ACR
data:image/s3,"s3://crabby-images/ec874/ec8743ff2dca70b8454c4cb35d8cb0911a9417ae" alt="docker-push.png docker-push.png"
到 Azure Web App for Containers 裡面可以看到剛剛推送的鏡像
data:image/s3,"s3://crabby-images/f5239/f5239f2248c420a439e7d21621319e42de8c72c3" alt="wac.png wac.png"
啟動命令
Python 主程式位於 src/main.py,所以啟動命令為
gunicorn main:app --chdir src
請依自身情況修改
CI/CD
預設是關閉的,打開後可以設定 CI/CD
data:image/s3,"s3://crabby-images/68667/686672f9959d350b267d2d7e10d713b1cbe68678" alt="container-cicd.png container-cicd.png"
設定時上方會有紅色警告,需要開啟基本驗證
data:image/s3,"s3://crabby-images/b8458/b8458c24c0133530035c44595ca8489484ca534c" alt="basicCred.png basicCred.png"
設定好後再回到 部屬中心最下方 Webhook URL 右方點擊複製
回到 ACR 的設定中,選擇 Webhook 設定
data:image/s3,"s3://crabby-images/d93c9/d93c9d78d60e0880c6a28a8fa25e0a4db0579543" alt="webhook.png webhook.png"
於 服務 URI
更新成剛剛複製的 URL
data:image/s3,"s3://crabby-images/61f8b/61f8bb09266aafa4367165af5a62d1c13575f301" alt="service-url.png service-url.png"
如果沒有就自己新增一個,之後可以點 Ping 來測試是否成功,正常會取得 202
data:image/s3,"s3://crabby-images/c7d85/c7d85e97bb90db1777d10dd51e68f7493c4ac999" alt="Ping202.png Ping202.png"
最後 Push 一次鏡像,就會自動部屬到 Web App
說明
服務 URI
是 Webhook URL,當鏡像 Push 到 ACR 後
會觸發一個 Post Request 到這個 URL
通知 Web App 這個鏡像要重新部屬。
錯誤
401 預設沒有啟用基本驗證,Webhook URL 中沒有帶帳號密碼,所以沒有權限可以 POST
404 錯誤的服務 URI,重新到 App Service 中複製一次 Webhook URL