data:image/s3,"s3://crabby-images/13270/132707f63491ed0d06074e2e2860256d148453d4" alt=""
This article has not been completed yet. However, it may already contain helpful Information and therefore it has been published at this stage.
Prerequisites:
- A server with an Arc Agent installed
Service Tags:
(that need to be checked / included.)
- AzureAD (previously AzureActiveDirectory)
- AzureTrafficManager
- AzureResourceManager
- AzureArcInfrastructure
- AzureStorage (previously Storage)
- WindowsAdminCenter
For a list of IP addresses for each service tag/region, see the JSON file below:
Download Link: Azure IP Ranges and Service Tags – Public Cloud.
Microsoft publishes weekly updates containing each Azure Service and the IP ranges it uses
I took the effort and built a fully automated solution for this.
Please find below the PowerShell - Script (Tags.ps1):
$rawhtml = Invoke-RestMethod -Uri 'https://www.microsoft.com/en-us/download/confirmation.aspx?id=56519' -UseBasicParsing
# Dowload https://www.microsoft.com/download/details.aspx?id=56519
# Source file location
$source = [Regex]::Match($rawhtml, 'https://download.microsoft.com[^"]*').Value
# Destination to save the file
$destination = 'c:\temp\ServiceTags_Public.json'
#Download the file
Invoke-WebRequest -Uri $source -OutFile $destination
$lookups='AzureArcInfrastructure','AzureAD','AzureTrafficManager','AzureResourceManager','AzureStorage','WindowsAdminCenter'
$ServiceTags = Get-Content -path c:\temp\ServiceTags_Public.json -Raw | ConvertFrom-Json
$region = $ServiceTags.values | Select-Object -expand properties | Select-Object @{Label="Region";Expression={($_.region)}} -Unique | Sort-Object -Property Region | Out-GridView -OutputMode Single -Title 'Select an Azure Region'
# $ServiceTags.values | Select-Object -expand properties | Select-Object region, systemService, addressPrefixes | Where-Object { $_.region -eq $region.Region -or $_.region -eq "" }
$result= @()
foreach ($lookup in $lookups){
$tagresult = $ServiceTags.values | Select-Object -expand properties | Select-Object region, systemService, addressPrefixes | Where-Object { $_.region -eq $region.Region -or $_.region -eq "" } | Where-Object { $_.systemService -eq $lookup}
$result += $tagresult
}
$result
# $result | Select-Object region,systemService
# $result | Select-Object -ExpandProperty addressPrefixes
Write-Output "---------------------------------------"
foreach ($object in $result) {
Write-Output "Service:" ($object.systemService).ToString()
Write-Output "Region: " ($object.region).ToUpper()
Write-Output "IP-Count: " $object.addressPrefixes.Count
Write-Output "IPs: " $object.addressPrefixes
Write-Output "---------------------------------------"
}
# Refernence:
# https://learn.microsoft.com/en-us/azure/azure-arc/servers/network-requirements?tabs=azure-cloud
Expected Result:
data:image/s3,"s3://crabby-images/4951a/4951adce06204d49ff7caf525ed2671ecb0119ed" alt=""
data:image/s3,"s3://crabby-images/2f49d/2f49dbeb5f4b23890d3c1fb524ec81d790d2d51c" alt=""
data:image/s3,"s3://crabby-images/cdb4a/cdb4a17903f50cbfa5028817227cad67d81219cc" alt=""
URLs to check:
(extracted from the official Microsoft documentation and the further references listed at the end of the blog post)
Static:
- aka.ms
- download.microsoft.com
- packages.microsoft.com
- management.azure.com
- login.windows.net
- login.microsoftonline.com
- pas.windows.net
- guestnotificationservice.azure.com
- dc.services.visualstudio.com
- www.office.com
Depending on the region:
- *.guestconfiguration.azure.com
- *.guestnotificationservice.azure.com
- *.his.arc.azure.com
- *.blob.core.windows.net
- azgn*.servicebus.windows.net
- *.servicebus.windows.net
Unfortunately, I was not able to verify / find out all the correct addresse
Microsoft's description is not 100% exact, even if it seems so when reading the following statement.
To translate the *.servicebus.windows.net
wildcard into specific endpoints, use the command \GET https://guestnotificationservice.azure.com/urls/allowlist?api-version=2020-01-01&location=<location>
. Within this command, the region must be specified for the <location>
placeholder.
This provides the following addresses:
data:image/s3,"s3://crabby-images/168e3/168e3f463fc9234dff2072411464409e18721c3e" alt=""
If you use the following URL you will also get a usable result for the *.his.arc.azure.com addresses:
https://gbl.his.arc.azure.com/discovery?location=westeurope&api-version=1.1-preview
data:image/s3,"s3://crabby-images/afdfa/afdfa9a1f254b1b600ec6c76f22b1bc821212560" alt=""
So the abbreviation for West Europe is "weu".
For the following addresses I could not collect any URLs.
# *.guestnotificationservice.azure.com
# Test-NetConnection "weu.guestnotificationservice.azure.com" -Port 443
# Test-NetConnection "westeurope.guestnotificationservice.azure.com" -Port 443
# Test-NetConnection "weuguestnotificationservice.azure.com" -Port 443
# Test-NetConnection "westeuropeguestnotificationservice.azure.com" -Port 443
# *.guestconfiguration.azure.com
# Test-NetConnection "weuguestconfiguration.azure.com" -Port 443
# Test-NetConnection "weu.guestconfiguration.azure.com" -Port 443
# Test-NetConnection "westeurope.guestconfiguration.azure.com" -Port 443
# Test-NetConnection "westeuropeguestconfiguration.azure.com" -Port 443
I included all these points in a script that handles them fully automatically:
data:image/s3,"s3://crabby-images/c354e/c354e16414921a00980fd963ae727adaffd2b2fc" alt=""
data:image/s3,"s3://crabby-images/2f49d/2f49dbeb5f4b23890d3c1fb524ec81d790d2d51c" alt=""
data:image/s3,"s3://crabby-images/5b874/5b87499fe7aeaab268ed3f4abf64f35a05f59b45" alt=""
data:image/s3,"s3://crabby-images/08f1e/08f1ea22b5aca70a079ac34a6b5300ccb416f822" alt=""
If there were any issues, they would show up at that point.
Modified Script - Connection.ps1:
$rawhtml = Invoke-RestMethod -Uri 'https://www.microsoft.com/en-us/download/confirmation.aspx?id=56519' -UseBasicParsing
# Dowload https://www.microsoft.com/download/details.aspx?id=56519
# Source file location
$source = [Regex]::Match($rawhtml, 'https://download.microsoft.com[^"]*').Value
# Destination to save the file
$destination = 'c:\temp\ServiceTags_Public.json'
#Download the file
Invoke-WebRequest -Uri $source -OutFile $destination
$lookups='AzureArcInfrastructure','AzureAD','AzureTrafficManager','AzureResourceManager','AzureStorage','WindowsAdminCenter'
$ServiceTags = Get-Content -path c:\temp\ServiceTags_Public.json -Raw | ConvertFrom-Json
$region = ($ServiceTags.values | Select-Object -expand properties | Select-Object @{Label="Region";Expression={($_.region)}} -Unique | Sort-Object -Property Region | Out-GridView -OutputMode Single -Title 'Select an Azure Region').Region
$urls = @('aka.ms','download.microsoft.com','packages.microsoft.com','management.azure.com','login.windows.net','login.microsoftonline.com','pas.windows.net','guestnotificationservice.azure.com','dc.services.visualstudio.com','www.office.com','agentserviceapi.guestconfiguration.azure.com')
# $ServiceTags.values | Select-Object -expand properties | Select-Object region, systemService, addressPrefixes | Where-Object { $_.region -eq $region.Region -or $_.region -eq "" }
# ((Invoke-RestMethod -Uri "https://gbl.his.arc.azure.com/discovery?location=$region&api-version=1.1-preview").split('.')[0]).substring(8)
# (Invoke-RestMethod -Uri "https://gbl.his.arc.azure.com/discovery?location=$region&api-version=1.1-preview")
$urls += (Invoke-RestMethod -Uri ("https://gbl.his.arc.azure.com/discovery?location=$region&api-version=1.1-preview")).substring(8)
$urls += (Invoke-RestMethod "https://guestnotificationservice.azure.com/urls/allowlist?api-version=2020-01-01&location=$region")
foreach ($url in $urls) {
if (((Test-NetConnection $url -Port 443 -WarningAction:SilentlyContinue).TCPTESTSucceeded) -ne $true) {Write-Host "$url is not reachable"}
$url
}
Verify the connection using the agent:
azcmagent check --location westeurope
Result:
data:image/s3,"s3://crabby-images/8e1f9/8e1f954fb5d68d577bec93f0b757763fc5122f23" alt=""
Check for Problems using the AMA - Troubleshooting - Tool
Open a PowerShell or Windows Terminal as an Administrator
data:image/s3,"s3://crabby-images/ed048/ed048dc532c0e2eaac63b0a8dff6f4c04c179ac7" alt=""
Change directory to:
cd "C:\Packages\Plugins\Microsoft.AzureMonitorWindowsAgent\<AMA Agent Version Number>\Troubleshooter"
data:image/s3,"s3://crabby-images/c8508/c8508cdd3ca171b204e524a5768f68b4464e853f" alt=""
Type AgentTroubleshooter.exe --ama
and press the ENTER
data:image/s3,"s3://crabby-images/0ad57/0ad57c3d63d229269951cd564e08721808a38f97" alt=""
Result:
data:image/s3,"s3://crabby-images/00466/00466c4726e9a64d530037e7a621d9a6a09c28f5" alt=""
data:image/s3,"s3://crabby-images/430a6/430a65f7917d099c2f6da10e4346ee032e051597" alt=""
data:image/s3,"s3://crabby-images/09c4a/09c4a7aba8a8b015f6dadff10732e87b399f1aa5" alt=""
If nothing helps and all the measures listed here do not provide any further information or progress, I recommend uninstalling the agent completely and then performing a clean reinstallation.
References:
Check if network connectivity for Azure Arc Connected Machine Agent is blocked
data:image/s3,"s3://crabby-images/65ead/65ead3cd8f394ae7280b937c4e57fec4577c6781" alt=""
data:image/s3,"s3://crabby-images/b72ab/b72ab7833b3994cf20f087af3f295644384821f8" alt=""
data:image/s3,"s3://crabby-images/cd80d/cd80d3dd84cd1dba82dc4795a7e6319e8fe42a79" alt=""
SOLVED: Missing Windows Server Agent Heartbeat – Check Azure Arc Status