Azure がメトリックを取得中に「認証に失敗しました」という問題が発生する

Azure がメトリックを取得中に「認証に失敗しました」という問題が発生する

Azure からメトリックを取得する PowerShell スクリプトを作成しています。Insights-UserMetric.Read.All (アプリケーション タイプ) への API アクセス許可を持つアプリ登録があります。また、サブスクリプション レベルでこのアプリに割り当てられた監視リーダー ロールもあります。スクリプトを実行すると、次のエラーが発生します。

{   "error": {     "code": "AuthenticationFailed",     "message": "Authentication failed."   } }

十分な権限がないかどうかを確認するために、役割を貢献者に上げようとしましたが、貢献者の役割でも同じエラーが発生します。

スクリプトは次のとおりです。

$ClientId = 'someClientId'
$ClientSecret = 'someClientSecret'
$Tenantid = 'someTenantId'

$TokenBody = @{
    Grant_Type = "client_credentials"
    Scope = "https://graph.microsoft.com/.default"
    Client_Id = $ClientId
    Client_Secret = $ClientSecret
}
$TokenResponse = Invoke-RestMethod -Uri "https://login.microsoftonline.com/$Tenantid/oauth2/v2.0/token" -Method POST -Body $TokenBody

$Headers = @{
    "Authorization" = "Bearer $($tokenResponse.access_token)"
    "Content-type" = "application/json"
}

$Uri = 'https://management.azure.com/subscriptions/$subscriptionId/resourceGroups/$resourceGroup/providers/Microsoft.EventHub/namespaces/$eventHub/providers/Microsoft.Insights/metrics?api-version=2018-01-01'

Invoke-RestMethod -Headers $Headers -Uri $Uri -Method GET

どのような指導でも歓迎します

答え1

問題は解決しました。トークン部分が修正されました:

$TokenBody = @{
    Grant_Type = "client_credentials"
    Scope = "https://management.azure.com/.default"
    Client_Id = $ClientId
    Client_Secret = $ClientSecret
    Tenant_Id = $TenantId
}

関連情報