點選上方藍字關註“汪宇傑部落格”
data:image/s3,"s3://crabby-images/2e17f/2e17f359826a60917e762048829fc8b2db150420" alt=""
今天我在為一個從TFVC遷移到Git的老專案重新配置釋出到Azure App Service的CI/CD管線的時候,Azure DevOps竟然爆了。這是一個微軟已知的bug,目前還未修複,我來帶大家看看如何手工workaround這個問題。
首先,部署的時候報錯訊息如下:
data:image/s3,"s3://crabby-images/154bc/154bcd2a609cb789f2d7a74f25e6ad394a0f0931" alt=""
Failed to get resource ID for resource type ‘Microsoft.Web/Sites’ and resourcename ‘moonglade’. Error: Could not fetch access token for Managed ServicePrincipal. Please configure Managed Service Identity (MSI) for virtual machine’https://aka.ms/azure-msi-docs’.Status code: 400, status message: Bad Request
本質上是因為Azure DevOps到Azure的連線無效,或者過期了。但是當我嘗試重新認證的時候,竟然又爆了:
TF14045: The identity with type ‘Microsoft.IdentityModel.Claims.ClaimsIdentity’ could not be found.
data:image/s3,"s3://crabby-images/1a44b/1a44bfbd584fb7e8fd7da77cb90d8c2f25ed30b9" alt=""
對此,微軟有個已知bug可以追蹤:https://developercommunity.visualstudio.com/content/problem/412380/tf14045-the-identity-with-type-microsoftidentitymo-1.html
解決方法
進入 Azure Active Directory > App registrations (Preview)
點選 “+ New registration“
data:image/s3,"s3://crabby-images/9839e/9839e214f2e8860466688665bc7fc448e1678a8b" alt=""
指定一個 Name,如 ediwang-AzureDevOps
選擇 “Accounts in this organizational directory only“
Redirection URL 填: https://VisualStudio/SPN
data:image/s3,"s3://crabby-images/b5fcc/b5fcc23c311b9ae321a31d19ac1ad10289cb55e4" alt=""
Description 任意,Expires 建議選 Never
data:image/s3,"s3://crabby-images/c15a6/c15a6b9da3a0b549bdf9406d1856df141e08ab42" alt=""
然後把 Client Secrets 裡的金鑰複製出來
data:image/s3,"s3://crabby-images/ce3c3/ce3c3b7c2165a93310ab5911d97a279851e4d878" alt=""
還有Overview 裡的 Application (client) ID 以及 Directory (tenant) ID
data:image/s3,"s3://crabby-images/a2f99/a2f99c45dc46f2998460ad63e6a0dc598c6f03b7" alt=""
然後到 Subscription > Access control (IAM) 裡搜尋剛才建立的App名字,搜到以後,Add a role assignment
data:image/s3,"s3://crabby-images/e6b7e/e6b7e84bcd6b53871905748bc8013ecd04966cac" alt=""
然後安排一個 Owner,Azure這邊就搞定了!
data:image/s3,"s3://crabby-images/358d6/358d62a446fbbb43e7e8538e8238ac7c8df79340" alt=""
然後回到 Azure DevOps
在 Azure App Service Deploy 的任務裡點 Manage
data:image/s3,"s3://crabby-images/3bc18/3bc18a08f0b6b9ee0891a5774498b8e1f7f03730" alt=""
在 Service Connections 裡新增一個 Azure Resource Manager
data:image/s3,"s3://crabby-images/302c2/302c2a1f12d908e22dbe3e979d894c2625c9f46d" alt=""
然後點“use the full version of the service connection dialog.”
data:image/s3,"s3://crabby-images/db14f/db14f012c531bcc381b411a01b4f201fe9835b09" alt=""
選擇和輸入對應的值。其中 Service pricipal client ID 就是剛才複製的 Application (client) ID,Service pricipal key 就是剛才 Client Secrets 裡複製的 VALUE
data:image/s3,"s3://crabby-images/24ec5/24ec5ccf0b87a71077fbc46c31c2e8dceb3b3f44" alt=""
最後點選 Verify connection,不成功便成仁!
data:image/s3,"s3://crabby-images/249ae/249ae555022a45c67ad98316b8eb88a3f01ed16e" alt=""
到此為止,就全部搞定了。重新回到你的部署任務裡,就能成功選擇標的Azure App Service上的網站了,並且能部署成功。
data:image/s3,"s3://crabby-images/1839f/1839f55b301aba54baa7537447775143e91692cf" alt=""
真是不容易……