How to onboard on-premise Server to Azure Arc by using a Site-to-Site IPSec VPN and Azure Arc Private Link Scope
Azure Arc Private Link Scope is a powerful feature that allows organizations to securely connect on-premises or multi-cloud resources to Azure services, leveraging private endpoints to ensure that traffic flows securely over private networks.
By extending Azure’s management and governance capabilities to resources outside the Azure environment, Azure Arc enables centralized control while keeping data secure within your private network.
In this post I will show step by step how to create the Azure Arc Private Link Scope, configure DNS properly that traffic will be routed through our VPN tunnel instead over the public internet, and finally how to onboard Windows and Linux machines to Azure Arc.
To say it right away, when configuring the Azure connected machine agent to communicate with Azure through a private link, some endpoints must still be accessed through the internet.
In the following article by Microsoft you will see which endpoints can be configured with a private endpoint and which must still be accessed through the internet.
Source: https://learn.microsoft.com/en-us/azure/azure-arc/servers/network-requirements?tabs=azure-cloud#urls
Introduction
Azure Arc Private Link Scope connects private endpoints (and the virtual networks they’re contained in) to an Azure resource, in this case Azure Arc-enabled servers.
Connectivity to any other Azure resource from an Azure Arc-enabled server requires configuring Private Link for each service, which is optional, but recommended. Azure Private Link requires separate configuration per service.
The Private Endpoint on your VNet allows it to reach Azure Arc-enabled servers endpoints through private IPs from your network’s pool, instead of using to the public IPs of these endpoints.
That allows you to keep using your Azure Arc-enabled servers resource without opening your VNet to outbound traffic not requested.
Traffic from the Private Endpoint to your resources will go over the Microsoft Azure backbone, and not routed to public networks.
You can configure each of your components to allow or deny ingestion and queries from public networks. That provides a resource-level protection, so that you can control traffic to specific resources.
Source: https://learn.microsoft.com/en-us/azure/azure-arc/servers/private-link-security#how-it-works
Azure Private Link allows you to securely link Azure PaaS services to your virtual network using private endpoints.
For many services, you just set up an endpoint per resource. This means you can connect your on-premises or multicloud servers with Azure Arc and send all traffic over an Azure ExpressRoute or site-to-site VPN connection instead of using public networks.
Starting with Azure Arc-enabled servers, you can use a Private Link Scope model to allow multiple servers or machines to communicate with their Azure Arc resources using a single private endpoint.
Source: https://learn.microsoft.com/en-us/azure/azure-arc/servers/private-link-security
Restrictions and limitations
Network traffic to Microsoft Entra ID and Azure Resource Manager does not traverse the Azure Arc Private Link Scope and will continue to use your default network route to the internet.
You can optionally configure a resource management private link to send Azure Resource Manager traffic to a private endpoint.
Remote access to the server using Windows Admin Center or SSH is not supported over private link at this time.
Checklist Setup Azure Arc Private Link Scope
- Establish a connection between your on-premises network and an Azure virtual network using a site-to-site VPN or ExpressRoute circuit.
- Deploy an Azure Arc Private Link Scope, which controls which machines or servers can communicate with Azure Arc over private endpoints and associate it with your Azure virtual network using a private endpoint.
- Update the DNS configuration on your local network to resolve the private endpoint addresses.
- Configure your local firewall to allow access to Microsoft Entra ID and Azure Resource Manager.
- Associate the machines or servers registered with Azure Arc-enabled servers with the private link scope.
Create a Private Link Scope
Go to Create a resource in the Azure portal and search for Azure Arc Private Link Scope, then select Create.
data:image/s3,"s3://crabby-images/0bc91/0bc9109d6d3767927eba2d5f8c7b76feeddcd79d" alt=""
Alternately, go directly to the Azure Arc Private Link Scopes page in the portal, then select Create Azure Arc Private link scope.
data:image/s3,"s3://crabby-images/9a370/9a370c89575a1be1932344a34abbc798284de3e7" alt=""
data:image/s3,"s3://crabby-images/94a08/94a08a6e5cea9f59b6e9893577be607ebb2dfad4" alt=""
In the Basics tab, select a subscription and resource group. Enter a name for the Azure Arc Private Link Scope. It’s best to use a meaningful and clear name.
Because I want that my Azure Arc-enabled servers are communicate just through a private endpoint, I will not check Allow public network access.
Optionally, you can require every Azure Arc-enabled machine or server associated with this Azure Arc Private Link Scope to send data to the service through the private endpoint. To do so, check the box for Allow public network access, so that machines or servers associated with this Azure Arc Private Link Scope can communicate with the service over both private or public networks. You can change this setting after creating the scope as needed.
data:image/s3,"s3://crabby-images/31515/315151f46a8b949afbcfeeabcc5a07e8239035db" alt=""
Select the Private endpoint tab, then select Create. Enter a Name for the endpoint.
Choose Yes for Integrate with private DNS zone, and let it automatically create a new Private DNS Zone.
Azure Arc sub-resource
The specific type of Arc resource that the private link scope will be able to access.
data:image/s3,"s3://crabby-images/0de21/0de21209cf6698e563690ecfe60bc6056869ccfb" alt=""
Click on Review + create.
data:image/s3,"s3://crabby-images/3d254/3d25472bf98fc14dc55a7e642fa3fccdfa1c99eb" alt=""
Let the validation pass, and then select Create.
data:image/s3,"s3://crabby-images/e4ead/e4ead99f9262d446c0194b966e251ef7d94b4c73" alt=""
The Azure Arc Private Link Scope will create the following resources:
- DNS Zone Group (links private endpoints to one or more Azure Private DNS zones. This allows your private endpoints to automatically register their DNS records in the private DNS zone, enabling seamless name resolution within your private network.)
- Virtual Network Links
- Private DNS zones
- Private endpoint
- Private link
data:image/s3,"s3://crabby-images/5e590/5e590543eb6be757cabd76eb1d0ca71fbf2050f0" alt=""
You will find the newly created Azure Arc private link scope in the Private Link Center.
data:image/s3,"s3://crabby-images/30cef/30cef4be4b495e0215838365515615ca825becfa" alt=""
On the Azure Arc private link scope blade you will see our newly created private endpoint under Configure -> Private Endpoint connections.
data:image/s3,"s3://crabby-images/fa790/fa79046e94038c6f3f44d540e930255c229f152e" alt=""
Clicking on the private endpoint above will open the private endpoint blade. Here we will see all private IP addresses and corresponding FQDNs for the Azure Arc services which are now accessible by using these private IP addresses and can be routed through the S2S VPN tunnel.
data:image/s3,"s3://crabby-images/2c0ef/2c0ef808b475eee0d7a481ef978afbda811a35a0" alt=""
When setting up our own on-premise DNS server to resolve these FQDNs into its private endpoints (IP addresses), we need to configure the following FQDNs.
data:image/s3,"s3://crabby-images/570a7/570a7acb3a0015b5c4751cca3d9b08c61d67927d" alt=""
Here we will see our newly created private DNS zones for the Azure Arc Private Link Scope.
data:image/s3,"s3://crabby-images/754a1/754a122c8267991a55d284990d5c66b2a0ea5646" alt=""
Within the private DNS zones we can see the A-records with the private IP addresses for the Azure Arc services.
data:image/s3,"s3://crabby-images/2e617/2e617de5b0f9a6af519f573ae758323a52fbb561" alt=""
The private DNS zones are linked to our virtual network.
data:image/s3,"s3://crabby-images/afdef/afdef58e05636fc0a34eb0ce46309839f1b947f5" alt=""
Your on-premises machines or servers need to be able to resolve the private link DNS records to the private endpoint IP addresses. How you configure this depends on whether you’re using Azure private DNS zones to maintain DNS records, or if you’re using your own DNS server on-premises and how many servers you’re configuring.
Further down we will also see how to maintain these DNS records by using both options, on our on-premise DNS servers and by using the Azure private DNS zones in combination with an Azure Private DNS resolver.
Create resource management private link
The Azure Resource Manager is not included in the Azure Arc Private Link Scope, to also route traffic for the Azure Resource Manager through our S2S VPN tunnel to Azure, we further need to create a resource management private link below.
Private links enable you to access Azure services over a private endpoint in your virtual network. When you combine private links with Azure Resource Manager’s operations, you block users who aren’t at the specific endpoint from managing resources. If a malicious user gets credentials to an account in your subscription, that user can’t manage the resources without being at the specific endpoint.
For this release, you can only apply private link management access at the level of the root management group. This limitation means private link access is applied across your tenant.
There are two resource types you’ll use when implementing management through a private link.
- Resource management private link (Microsoft.Authorization/resourceManagementPrivateLinks)
- Private link association (Microsoft.Authorization/privateLinkAssociations)
In the portal, search for Resource management private links and select it from the available options.
data:image/s3,"s3://crabby-images/eb28d/eb28d63ad63a415958d3a5fc8009b493f8aa1cd9" alt=""
If your subscription doesn’t already have resource management private links, you see a blank page. Select Create resource management private link.
data:image/s3,"s3://crabby-images/6283b/6283b94d3dd049c85e194f96ea5e6473d6894498" alt=""
Provide values for the new resource management private link. The root management group for the directory you selected is used for the new resource. Select Review + create.
data:image/s3,"s3://crabby-images/b20c6/b20c6e76bebcf9e7b31d3dd5fab45899aec491c3" alt=""
After validation passes, select Create.
data:image/s3,"s3://crabby-images/e5bac/e5bace676e5361115152073d2eb71ef760ff8b81" alt=""
Next, create a private endpoint that references the resource management private link.
Navigate to the Private Link Center. Select Create private endpoint.
data:image/s3,"s3://crabby-images/eb986/eb986121ddc2e913ea2f23a4c2cb57f1cb00232f" alt=""
In the Basics tab, provide values for your private endpoint.
data:image/s3,"s3://crabby-images/26397/26397ca1d09528666bda58624623b4db2b431fe6" alt=""
In the Resource tab, select Connect to an Azure resource in my directory. For resource type, select Microsoft.Authorization/resourceManagementPrivateLinks. For target subresource, select ResourceManagement.
data:image/s3,"s3://crabby-images/a04fc/a04fc1a126d21cf202eee6ec4db34d97c8a7b1eb" alt=""
In the virtual network tab select your virtual network.
data:image/s3,"s3://crabby-images/cbf82/cbf82bfa33067d168ef3e453b75f193327eeec7c" alt=""
In the DNS tab Microsoft recommends to use a private DNS zone, just for testing purpose in my lab environment I want to save the costs and choose here No. I will configure this on my on-premise DNS server later.
Finally its not about the price of the Azure private DNS zones itself in Azure, but about the Azure DNS Private resolver costs for endpoints and rulesets, which are really expensive. When using here Azure private DNS zones, we also need the Azure DNS Private resolver to forward on-premise DNS queries to Azure as shown further down.
Azure DNS pricing
https://azure.microsoft.com/en-us/pricing/details/dns/
data:image/s3,"s3://crabby-images/6f162/6f162fcb772061041e07e26c906ac3a573981648" alt=""
After validation passes, select Create.
We first note the DNS records within the newly created private endpoint. We need to configure them on our on-premise DNS server.
data:image/s3,"s3://crabby-images/b6f50/b6f50cc733c3ec8eaacec5f4b634e34eec034306" alt=""
Configured on my on-premise DNS server.
data:image/s3,"s3://crabby-images/fadd6/fadd6c318923e220bc32a0e118bac1d25d8a01c4" alt=""
I will also configure my squid proxy to bypass traffic for the *.management.azure.com domain. Traffic should be from now on forwarded directly to the private IP address 172.20.10.4/24 which will be routed through the VPN tunnel with Azure.
data:image/s3,"s3://crabby-images/054d3/054d324c4f18cbaf32115f6c1b664b373ff87c76" alt=""
And or directly on the client. Depends on your local network configuration.
data:image/s3,"s3://crabby-images/7dfce/7dfceccb2c3bb48b3ff86edb750ee26ad433907d" alt=""
DNS configuration using Azure-integrated private DNS zones
Below I will show how to use Azure-integrated private DNS zones and Azure DNS Private resolver for our private endpoint in Azure Arc.
Meanwhile I was changing this to use my on-premise DNS server therefore which will not comes with additional costs.
Finally its not about the price of the Azure private DNS zones itself in Azure, but about the Azure DNS Private resolver costs for endpoints and rulesets, which are really expensive. When using here Azure private DNS zones, we also need the Azure DNS Private resolver to forward on-premise DNS queries to Azure.
Azure DNS pricing
https://azure.microsoft.com/en-us/pricing/details/dns/
If you set up private DNS zones for Azure Arc-enabled servers and Guest Configuration when creating the private endpoint, your on-premises machines or servers need to be able to forward DNS queries to the built-in Azure DNS servers to resolve the private endpoint addresses correctly.
You need a DNS forwarder in Azure (either a purpose-built VM or an Azure Firewall instance with DNS proxy enabled), after which you can configure your on-premises DNS server to forward queries to Azure to resolve private endpoint IP addresses.
Azure DNS Private Resolver with on-premises DNS Conditional Forwarder
This configuration can be extended for an on-premises network that already has a DNS solution in place.
The on-premises DNS solution is configured to forward DNS traffic to Azure DNS via a conditional forwarder. The conditional forwarder references the Private Resolver deployed in Azure.
Azure DNS Private Resolver is a new service that enables you to query Azure DNS private zones from an on-premises environment and vice versa without deploying VM based DNS servers.
Source: https://learn.microsoft.com/en-us/azure/dns/dns-private-resolver-overview
Create an Azure DNS Private Resolver using the Azure portal
Open the Azure portal and search for DNS Private Resolvers.
data:image/s3,"s3://crabby-images/7ba15/7ba15141ef03c72f3799af8a8290895dc9eabb14" alt=""
Select DNS Private Resolvers, select Create, and then on the Basics tab for Create a DNS Private Resolver enter the following information a shown.
data:image/s3,"s3://crabby-images/169e1/169e1ce6dbaae08e2aac9be84c462a7a61279b07" alt=""
We also need to select here the virtual network for which our private resolver will be provided.
data:image/s3,"s3://crabby-images/88ae0/88ae067a92115fcd5e7933b117d521cd490a6ea8" alt=""
Select the Inbound Endpoints tab, select Add an endpoint, and then enter a name next to Endpoint name (ex: myinboundendpoint).
Static and dynamic endpoint IP addresses
https://learn.microsoft.com/en-us/azure/dns/private-resolver-endpoints-rulesets#static-and-dynamic-endpoint-ip-addressesNo other resources can exist in the same subnet with the inbound endpoint. Best practices is to user here a dedicated /28 subnet for.
Source: https://learn.microsoft.com/en-us/azure/dns/private-resolver-endpoints-rulesets#inbound-endpoints
data:image/s3,"s3://crabby-images/a5e9c/a5e9c4f582d04d67841b8d5c43317870adcd49fc" alt=""
Later we need to configure the conditional DNS forwarder on our on-premise DNS servers to forward requests to this inbound endpoint which will be created in the default subnet of the Azure VNet.
data:image/s3,"s3://crabby-images/6728e/6728e8ae757b18b42def95e2e4a84d15ab0d52ae" alt=""
Select the Outbound Endpoints tab, select Add an endpoint, and then enter a name next to Endpoint name (ex: myoutboundendpoint).
Outbound endpoints can forward domain name resolution (DNS) requests. To complete your configuration, create rulesets later that point to these endpoints.
The outbound endpoint must be created in a different dedicated subnet.
An outbound endpoint is associated with a subnet, but isn’t provisioned with an IP address like the inbound endpoint.
No other resources can exist in the same subnet with the outbound endpoint.
Best practices is to user here a dedicated /28 subnet for.
Source: https://learn.microsoft.com/en-us/azure/dns/private-resolver-endpoints-rulesets#outbound-endpoints
data:image/s3,"s3://crabby-images/9e0c8/9e0c8afe5bfc49ec71ac851e4316363f08dd29a3" alt=""
data:image/s3,"s3://crabby-images/f0784/f0784d2ca0132c022f602b70f4252053afe5048e" alt=""
Select the Ruleset tab, select Add a ruleset, and enter the following.
data:image/s3,"s3://crabby-images/68576/68576bd0852215ed1c5ee599ade474bb333acfe2" alt=""
Under Rules, select Add and enter your conditional DNS forwarding rules. For example:
This will forward DNS requests for my internal Active Directory domain matrixpost-lab.net made by virtual machines running in the linked VNet VNet-AzureArc to my on-premise DNS server.
data:image/s3,"s3://crabby-images/3806a/3806a75581bd1d184a81990c08b442d3247571f4" alt=""
This example has only one conditional forwarding rule, but you can create many. Edit the rules to enable or disable them as needed.
data:image/s3,"s3://crabby-images/e9cfa/e9cfa581d5faa8f42fb0295861f902265069d615" alt=""
data:image/s3,"s3://crabby-images/459d8/459d854f8452eaefa87421f283d5345c465262b7" alt=""
data:image/s3,"s3://crabby-images/44b80/44b80d59580ae07f8b895cf6eab9d70b0122d477" alt=""
To create a conditional forwarder we need the domain we want to forward dns requests for and the IP address or FQDN of the DNS server for this domain.
data:image/s3,"s3://crabby-images/3b0e3/3b0e34d3fa0062bdc60fab3d1ad1b6f0d9d5848a" alt=""
The domain we can see in the previously created private dns zone for Azure Arc enabled servers service as highlighted below.
data:image/s3,"s3://crabby-images/b06a0/b06a0108514cdad3662fc9fd6d402d1de9c24007" alt=""
The IP address we can determine within the DNS private resolver and here our created inbound endpoint.
data:image/s3,"s3://crabby-images/5b9ed/5b9ed2c9e922544e133c8ad74b87bbc6d5b5de56" alt=""
data:image/s3,"s3://crabby-images/080b9/080b9a8f03c3445a6bf84377b058f99792e0b9db" alt=""
A quick test if DNS resolution works. Looks good and the A-records from the Azure private DNS zones with the private IP addresses will returned.
data:image/s3,"s3://crabby-images/6d967/6d9676d2200f88f5ba6aeb3b57cec2ba568fa8b1" alt=""
Connect to an Azure Arc-enabled server (Windows)
Using private endpoint requires the Azure Connected Machine agent version 1.4 or higher. The Azure Arc-enabled servers deployment script generated in the portal downloads the latest version.
The version of the Azure Connected Machine agent you can determine by running the following command on the affected server.
> azcmagent.exe --version
data:image/s3,"s3://crabby-images/6debf/6debfa4cb90752517370cfafdd0d9862d0268f87" alt=""
When connecting a machine or server with Azure Arc-enabled servers for the first time, you can optionally connect it to a Private Link Scope.
In the Azure portal navigate to Navigate to Machines – Azure Arc.
data:image/s3,"s3://crabby-images/4971b/4971b2a7dad1c2fdd1b01768af4606b74cff5d60" alt=""
On the Machines – Azure Arc page, select Add/Create at the upper left, and then select Add a machine from the drop-down menu.
data:image/s3,"s3://crabby-images/b1c82/b1c8242bdd33690b26cf21ba61163e23cbe71f75" alt=""
On the Add servers with Azure Arc page, select either the Add a single server or Add multiple servers depending on your deployment scenario, and then select Generate script.
I will first show how to add a single server below. Click on Generate script.
data:image/s3,"s3://crabby-images/975b9/975b9f6169b81455ac9e892186ac49ce77717a9b" alt=""
On the Basics page, provide the following.
data:image/s3,"s3://crabby-images/b7f7f/b7f7f91d52025bafc0ef2fd0746b7151bc3de8e1" alt=""
At the bottom of the Basics tab we can configure the connectivity method for the Azure Connected Machine agent.
We want to use our previously configured private endpoint and private link scope which we can select here.
data:image/s3,"s3://crabby-images/53244/5324437b30e5d3b9dc9020961c905437882f1197" alt=""
In the Download and run script tab we can download the script to run later on the affected server.
data:image/s3,"s3://crabby-images/fff44/fff443c8f60b1384396ff8623f00610045af9d9e" alt=""
After downloading the script, you have to run it on your machine or server using a privileged (administrator or root) account.
Depending on your network configuration, you might need to download the agent from a computer with internet access and transfer it to your machine or server, and then modify the script with the path to the agent.
The Windows agent can be downloaded from https://aka.ms/AzureConnectedMachineAgent and the Linux agent can be downloaded from https://packages.microsoft.com.
Look for the latest version of the azcmagent under your OS distribution directory and installed with your local package manager.
The script will return status messages letting you know if onboarding was successful after it completes.
Network traffic from the Azure Connected Machine agent to Microsoft Entra ID (login.windows.net, login.microsoftonline.com, pas.windows.net) will continue to use public endpoints.
Most of these services already offer private endpoints, but you need to configure your firewall and routing rules to allow access to Microsoft Entra ID and Azure Resource Manager over the internet until these services offer private endpoints.
In the following article by Microsoft you will see which endpoints can be configured with a private endpoint and which must still be accessed through the internet.
https://learn.microsoft.com/en-us/azure/azure-arc/servers/network-requirements?tabs=azure-cloud#urls
If your server needs to communicate through a proxy server to reach these endpoints, configure the agent with the proxy server URL before connecting it to Azure. You might also need to configure a proxy bypass for the Azure Arc services if your private endpoint is not accessible from your proxy server.
So for machines without direct internet access, we need to allow public access to Microsoft Entra ID and Azure Resource Manager on the proxy.
Therefore we finally need to allow outbound traffic to the following domains in order to connect our on-premise machines and server to Azure Arc by using our existing site-to-site IPSec VPN connection and HTTP proxy. In the URLs link below you will see a description for each domain and if a private link is supported by now.
- download.microsoft.com ==> Used to download the Windows installation package
- packages.microsoft.com ==> Used to download the Linux installation package
- .microsoftonline.com ==> Microsoft Entra ID
- .*login.microsoft.com ==> Microsoft Entra ID
- .pas.windows.net ==> Microsoft Entra ID
- .management.azure.com ==> traffic routed through site-to-site VPN tunnel and private link. (provided a resource management private link is configured as we did further above.)
- .his.arc.azure.com ==> traffic routed through site-to-site VPN tunnel and private link.
- .guestconfiguration.azure.com ==> traffic routed through site-to-site VPN tunnel and private link.
- .guestnotificationservice.azure.com ==> Extension management and guest configuration services
- .servicebus.windows.net ==> For Windows Admin Center and SSH scenarios
URLs
When configuring the Azure connected machine agent to communicate with Azure through a private link, some endpoints must still be accessed through the internet.The Private link capable column in the following table shows which endpoints can be configured with a private endpoint.
If the column shows Public for an endpoint, you must still allow access to that endpoint through your organization’s firewall and/or proxy server for the agent to function. Network traffic is routed through private endpoint if a private link scope is assigned.
Source: https://learn.microsoft.com/en-us/azure/azure-arc/servers/network-requirements?tabs=azure-cloud#urls
Before executing the downloaded OnboardingScript.ps1 script, we first need to make sure, that the agent can reach the required public endpoints which are only available through the internet like Microsoft Entra ID (login.microsoftonline.com).
Below the server will use the HTTP proxy on which we allowed the required public endpoints shown above.
If the private endpoint is not accessible from our proxy server, we also need to bypass these private endpoints to which the agent connects to by using a direct connection to our VPN appliance and its S2S IPSec VPN tunnel with Azure. Then we need to add the*.his.arc.azure.com, *.guestconfiguration.azure.com and *.management.azure.com domain below in the bypass list.
My squid proxy is also able to access the private endpoints through the S2S VPN tunnel and therefore doesn’t need to configure them on the bypass list. Finally my clients can access them by using a direct connection to the internal VPN appliance (pfSense) or through my squid proxy.
data:image/s3,"s3://crabby-images/e0e95/e0e95df2772db6db929a055d52f854e8a953c8f1" alt=""
Because the Azure Connected Machine agent will not by default use the proxy configuration from the OS above, we also need to set the proxy directly in the OnboardingScript.ps1 script as shown below.
Here we can also add both private endpoints with *.his.arc.azure.com, *.guestconfiguration.azure.com and *.management.azure.com to bypass the proxy if the private endpoint is not accessible from our proxy server.
Therefore we can use here the service name that shouldn’t use the proxy server. For the *.his.arc.azure.com and*.guestconfiguration.azure.com domain we need to use here the Arc value and for the *.management.azure.com domain the ARM value.
Starting with agent version 1.15, you can also specify services which should not use the specified proxy server. This can help with split-network designs and private endpoint scenarios where you want Microsoft Entra ID and Azure Resource Manager traffic to go through your proxy server to public endpoints but want Azure Arc traffic to skip the proxy and communicate with a private IP address on your network.
# Set Proxy Settings for Azure Connected Machine Agent & "$env:ProgramW6432\AzureConnectedMachineAgent\azcmagent.exe" config set proxy.url "http://10.0.0.254:3128" & "$env:ProgramW6432\AzureConnectedMachineAgent\azcmagent.exe" config set proxy.bypass "Arc,ARM" # check configuration azcmagent.exe config list # clear the proxy.bypass azcmagent.exe config clear proxy.bypass # clear proxy.url azcmagent.exe config clear proxy.url
data:image/s3,"s3://crabby-images/46a81/46a810cfa40e3c4976a8923f2d310cb4cd2d2468" alt=""
Finally the machine was connected successful to Azure Arc enabled servers.
data:image/s3,"s3://crabby-images/7ccf5/7ccf537e40b8270dd8a39467ba2b27ca0371c9af" alt=""
Looks good!
data:image/s3,"s3://crabby-images/187b4/187b419c6f99b641af13f7c1a47e9499923cdadc" alt=""
The server is connected to Azure Arc.
data:image/s3,"s3://crabby-images/29c28/29c28ade3f557dd7667d0138760f59407b105c6c" alt=""
data:image/s3,"s3://crabby-images/657db/657dbfbec32775656ae89c079ef4d88316aa5d35" alt=""
Adding multiple servers to Azure Arc
If we select Add multiple servers on the Authentication page, we also need to select a service principal created for Azure Arc-enabled servers from the drop-down list.
If you haven’t created a service principal for Azure Arc-enabled servers, review how to create a service principal to learn about permissions and steps required to create one.
You can automate the onboarding of multiple servers with minimal permissions using a service principal instead of enabling a single server interactively. The built-in “Azure Connected Machine Onboarding” role allows the service principal to onboard servers to Azure Arc.
Select Next: Tags to continue.
data:image/s3,"s3://crabby-images/220db/220dbe4e55ce0886860c3924f269c54cf8efc7e9" alt=""
data:image/s3,"s3://crabby-images/09317/09317fd90f67f2d0748afce3fe8e6d259ba5d962" alt=""
data:image/s3,"s3://crabby-images/3dab0/3dab03764218f57ef249c4a1cb584f07033070d8" alt=""
I will first have to create a new service principal. The service principal needs the Azure Connected Machine Role assigned to.
data:image/s3,"s3://crabby-images/fe9ed/fe9ed8ee8c771a82e06177276d5350b73270d92f" alt=""
We can either click on the link above with Create new to create a new service principal for the Azure Arc Services authentication or we can navigate to Azure Arc and here expand Management and click on Service principals as shown below.
data:image/s3,"s3://crabby-images/cdff0/cdff00475740fec277a9a8c4a6625405c3030ad1" alt=""
Choose whether the service principal will have access to an entire subscription, or only to a specific resource group.
In the Client secret section, select the duration for which your generated client secret will be in use. You can optionally enter a friendly name of your choice in the Description field.
In the Role assignment section, select Azure Connected Machine Onboarding and finally click on Create.
data:image/s3,"s3://crabby-images/b788a/b788aa64fabe2a5eac31f0273e8e7047142a5fdf" alt=""
Next we need to download here the service principal ID and secret, we are not able to retrieve the client secret later after leaving this page.
data:image/s3,"s3://crabby-images/1fb87/1fb87946d3128c06ffe93411b99c05265f131ed5" alt=""
data:image/s3,"s3://crabby-images/6f9cf/6f9cf322054628591bf007020f1c27dba2ff222a" alt=""
When clicking above on the service principal we can see below that the client secret can’t be retrieved here again.
In case we not noted it, we can create a new one below or also, in case our onboarding delays and the client secret expires, we can also create here a new one.
data:image/s3,"s3://crabby-images/0c112/0c11228656a4e5572e70a9785e8a93a0b6dc7d94" alt=""
We can now select this service principal below for adding multiple servers to Azure Arc.
data:image/s3,"s3://crabby-images/84109/84109f27e2b0ca32a86e613b8cd4bea4ebf0b74e" alt=""
On the Download and run script page, review the summary information, and then select Download.
data:image/s3,"s3://crabby-images/21af6/21af6e22d9bdadddab4fd7d8e6bd5c213048e3b7" alt=""
The process of onboarding multiple servers to Azure Arc finally is nearly the same as previously for a single server.
The only difference is, that for a single server when executing the onboarding PowerShell script named OnboardingScript.ps1, we need to authenticate interactively by using a regular user account.
data:image/s3,"s3://crabby-images/fa6cd/fa6cd266272c7ed27bb11ae68070e296060a57ac" alt=""
In contrast when using the OnboardingScript.ps1 generated for adding multiple servers, the authentication will occur automatically transparent by using our previously created and assigned service principal.
We can now see, that our OnboardingScript.ps1 to add multiple servers and using a service principal to authenticate to Entra ID, will also include the service principal ID and its client secret.
!! Note !! The client secret is not added by default for security reasons and needed to be entered before we can execute the script to install and connect the agent to Azure Arc.
data:image/s3,"s3://crabby-images/c7b03/c7b03ad86255324b347ab70ecd4d8734dd947b61" alt=""
We also first need to add our proxy settings as previously when onboarding a single server.
# Set Proxy Settings for Azure Connected Machine Agent & "$env:ProgramW6432\AzureConnectedMachineAgent\azcmagent.exe" config set proxy.url "http://10.0.0.254:3128" & "$env:ProgramW6432\AzureConnectedMachineAgent\azcmagent.exe" config set proxy.bypass "Arc,ARM"
data:image/s3,"s3://crabby-images/4efc6/4efc6e2d5699151113cc89bcbeaf8d363e107b5a" alt=""
Further we also need to configure the proxy bypass list on the OS directly if the private endpoint is not accessible from our proxy server.
The first the script will try is to download the agent package (AzureConnectedMachineAgent.msi) by using the Invoke-WebRequest cmdlet and URL https://gbl.his.arc.azure.com/azcmagent-windows.
The Invoke-WebRequest cmdlet will use therefore the proxy settings of the OS.
So exclude *.his.arc.azure.com, *.guestconfiguration.azure.com and *.management.azure.com from the proxy as shown below. We can also configure to bypass these domains directly on the proxy.
data:image/s3,"s3://crabby-images/e0e95/e0e95df2772db6db929a055d52f854e8a953c8f1" alt=""
Now we can finally run the OnboardingScript.ps1 script.
> .\OnboardingScript.ps1
data:image/s3,"s3://crabby-images/1c299/1c2995ab4cb8d0c61d487c452dc5eaae5dbf1d63" alt=""
Looks good and the server is connected to Azure Arc.
data:image/s3,"s3://crabby-images/7acc0/7acc070603a4e91a5969a6411de14e7e7c6d6be2" alt=""
Connect to an Azure Arc-enabled server (Linux)
The Azure Arc-enabled servers deployment script generated in the portal downloads the latest version.
The version of the Azure Connected Machine agent you can determine by running the following command on the affected server.
# azcmagent --version
data:image/s3,"s3://crabby-images/68581/6858142130aae676d62139647d352e1d22af4817" alt=""
When connecting a machine or server with Azure Arc-enabled servers for the first time, you can optionally connect it to a Private Link Scope.
In the Azure portal navigate to Navigate to Machines – Azure Arc.
Under Operating System we can choose between Windows and Linux.
data:image/s3,"s3://crabby-images/e9aef/e9aefe32f1d2139a853256534afe1e815ac13916" alt=""
At the bottom of the Basics tab we can configure the connectivity method for the Azure Connected Machine agent.
We want to use our previously configured private endpoint and private link scope which we can select here.
data:image/s3,"s3://crabby-images/0f70b/0f70b97c0b92facc00f99ffae394d62978d20797" alt=""
In the Download and run script tab we can download the script to run later on the affected server.
data:image/s3,"s3://crabby-images/e131d/e131d70201cff97d5180fc68538bd6762af8a1ea" alt=""
We can now either just run bash OnboardingScript.sh or first make the script explicitly executable to use ./OnboardingScript.sh.
More about using different methods to execute a shell script in Linux you will find in my following post https://blog.matrixpost.net/linux-executing-shell-scripts-different-ways/.
data:image/s3,"s3://crabby-images/946fe/946fe20c016836a84cee9f99b8891ca159e820a1" alt=""
Below I will run into an error because the OS will try to make a connection through the configured HTTP proxy which for this domain not allowed and instead the S2S VPN tunnel with Azure should be used.
data:image/s3,"s3://crabby-images/dd770/dd7700625cf83321a23531098fbfc91de5a80f2a" alt=""
Checking with the wget command again.
Proxy tunneling failed: ForbiddenUnable to establish SSL connection.
data:image/s3,"s3://crabby-images/64b99/64b99cf28b2772d109d6e83b0fd47e815e4a5803" alt=""
So we also need to configure on Linux the bypass list to exclude traffic for .his.arc.azure.com, .guestconfiguration.azure.com and .management.azure.com to finally route this traffic through the S2S VPN tunnel instead the proxy. Or in case the private endpoint is accessible from our proxy server, we need to allow traffic for these domains.
To bypass them on the client.
# vi /etc/sysconfig/proxy
Note: For the setting to take effect immediately you will need to either log out and back in or export the proxy variables via the terminal session.
data:image/s3,"s3://crabby-images/3e596/3e596bed4a2caae15760993b5a298e92253bc0e4" alt=""
Allow traffic on the squid proxy directly.
The always_direct directive specifies requests which should ALWAYS be forwarded by Squid to the origin servers without using any peers.
The domains needs to be added also below for the acl named allowed_https_sites.
data:image/s3,"s3://crabby-images/b2eb8/b2eb8fc25cf78e939a6e735dc04f43ee98e02655" alt=""
Failed to connect to packages.microsoft.com port 443.
data:image/s3,"s3://crabby-images/59a68/59a687c42bf9575667406a2c93b8e02d364bb6ef" alt=""
So we also need to allow outbound traffic to https://packages.microsoft.com on the proxy.
data:image/s3,"s3://crabby-images/4708f/4708fa7bba0a1a531d42d358f122f21fc3b2cedb" alt=""
Here we nevertheless run into the same error, the reason for is, that the install_linx_azcmagent.sh script will not use the configured proxy for the OS and instead is using here its own settings, by default no proxy is configured.
data:image/s3,"s3://crabby-images/d5304/d53049850118ffe6afa04a4642352f6b2e6b888a" alt=""
So we need to adjust the install_linx_azcmagent.sh script and adding our proxy to the configuration.
# vi /tmp/install_linx_azcmagent.sh proxy="http://10.0.0.254:3128"
data:image/s3,"s3://crabby-images/070f4/070f40624f84a517af347fb07148bcb6a0ba1ea3" alt=""
Now instead running again the OnboardingScript.sh, we should directly execute the tmp/install_linux_azcmagent.sh script.
Otherwise when running the OnboardingScript.sh again, the install_linux_azcmagent.sh would be downloaded again and overwrites our adjusted install_linux_azcmagent.sh script.
Ignore the path below with ~/install_linux_azcmagent.sh for the root home folder, the reason for is that I also tried to download the install_linux_azcmagent.sh script directly as described in the article by Microsoft below. The file is the same as when using our in Azure generated OnboardingScript.sh script.
The OnboardingScript.sh we finally nevertheless needs to run to connect the agent to our tenant, subscription and resource group. But before we need to comment out some lines as shown further down to not overwrite and run the install_linux_azcmagent.sh again.
Install and validate the agent on Linux
https://learn.microsoft.com/en-us/azure/azure-arc/servers/onboard-portal#install-and-validate-the-agent-on-linux
Below I will run into another error because https://scc.suse.com so far is not allowed on the proxy and therefore the SLES OS couldn’t retrieve or update packages.
data:image/s3,"s3://crabby-images/a4177/a41775d657fa32faae7d1bb1ad84a65f986f9e7d" alt=""
So we also need to allow traffic to https://scc.suse.com on the proxy.
data:image/s3,"s3://crabby-images/89953/899538c046d0c9b62107677c341fa4325d03719a" alt=""
Let’s try it again.
data:image/s3,"s3://crabby-images/db84f/db84f9a30c6c6ea7a7b6c5360480cea116968ab7" alt=""
data:image/s3,"s3://crabby-images/2463f/2463f84447f991d18d74f5e1f7c75d015392e049" alt=""
Looks good and the agent was installed successfully.
data:image/s3,"s3://crabby-images/79c09/79c09ea2fed14ce2b2f3bf4053e7544df4cc199a" alt=""
The next step is to connect the installed agent to Azure Arc, therefore we first need to adjust the OnboardingScript.sh script and commenting some lines out as mentioned.
Below I will comment out the part where the agent and install_linux_azcmagent.sh script will be downloaded and executed.
If not this would overwrite our adjusted install_linux_azcmagent.sh script where we added our proxy previously and then would try to re-install the agent and this time because of the missing proxy setting would run into an error.
So comment the following both sections #Download the installation package andl #Install the hybrid agent as shown below. Finally just the connecting to Azure Arc will be executed.
data:image/s3,"s3://crabby-images/d02a2/d02a2f4c096111c67e5998ab8cce4e99e28f7c78" alt=""
One final setting before we can run the OnboardingScript.sh again.
By default the Connected Machine agent for Linux will not use the proxy settings of the OS, same as with the Windows agent.
Therefore we first need to execute the following commands to set our proxy settings for the agent.
azcmagent config set proxy.url "http://10.0.0.254:3128" azcmagent config set proxy.bypass "Arc,ARM" # checking with azcmagent config list
data:image/s3,"s3://crabby-images/59bd8/59bd8af452101fc1aabb41299ae2bd3810ea0442" alt=""
Now finally we can run the OnboardingScript.sh again to connect the agent to Azure Arc.
# bash OnboardingScript.sh
By the way as you can see below, to authorize a device that don’t have a keyboard or event don’t have a browser, the device authorization flow will be used in OAuth. More about OAuth and OpenID Connect you will also find in my following post https://blog.matrixpost.net/oauth-2-0-and-openid-connect-deep-dive/.
data:image/s3,"s3://crabby-images/3fdb0/3fdb0ac4780d942fdd741ef2c3f0a5fe6505df0f" alt=""
The Linux virtual machine is connected successfully to Azure Arc.
data:image/s3,"s3://crabby-images/7f9df/7f9dfb4245a6ce705e2bdb87ddc4c8538c12c385" alt=""
We can check the connection status also directly on the Linux machine by executing the following command.
# azcmagent show | grep -e 'Agent Status' -e 'Agent Version' -e 'Using HTTPS Proxy' -e 'Proxy Bypass List'
data:image/s3,"s3://crabby-images/d2fdd/d2fddbee94f273338c0d2f957f91c6a78e014623" alt=""
We can also check if the Azure Connected Machine Agent Service is enabled and running on Linux by checking the himdsd.service.
# systemctl status himdsd.service
data:image/s3,"s3://crabby-images/d61d3/d61d3affcaaabbbe5d24eef18771ec3e3b7eb16f" alt=""
This service implements the Hybrid Instance Metadata service (IMDS) to manage the connection to Azure and the connected machine’s Azure identity.
Linux agent installation details
https://learn.microsoft.com/en-us/azure/azure-arc/servers/agent-overview#linux-agent-installation-details
To disconnect the agent we can use the following command.
# azcmagent disconnect
data:image/s3,"s3://crabby-images/ce146/ce1467e6a2c4626a70278660e688280d9fc2a9bd" alt=""
Azure Arc Proxy
In case you also wondering about what the heck is Azure Arc Proxy, especially when we previously configured directly a proxy by using the Azure connected machine agent (azcmagent.exe) itself and the following command.
> azcmagent.exe config set proxy.url "<proxy fqdn or ip address:port>"
data:image/s3,"s3://crabby-images/0477b/0477b6c819ba0fba0bfdeb296d92931ddd6ab3a8" alt=""
The Azure Arc Proxy runs as a Network Service on Windows and a standard user account (arcproxy) on Linux. It’s disabled by default until you configure the agent to use the Azure Arc gateway (Limited preview).
Source: https://learn.microsoft.com/en-us/azure/azure-arc/servers/agent-overview#azure-arc-proxy
So finally the Azure Arc Proxy is only needed in case you will use the Azure Arc gateway, another way for secure connectivity to Azure Arc instead Azure Arc Private Link Scope.
Azure Arc gateway consists of two main components:
- The Arc gateway resource: An Azure resource that serves as a common front-end for Azure traffic. This gateway resource is served on a specific domain. Once the Arc gateway resource is created, the domain is returned to you in the success response.
- The Arc Proxy: A new component added to Arc agentry. This component runs as a service called “Azure Arc Proxy” and acts as a forward proxy used by the Azure Arc agents and extensions. No configuration is required on your part for the Arc Proxy. This Proxy is part of Arc core agentry and runs within the context of an Arc-enabled resource.
More about the Azure Arc gateway (Public Preview) you will find in the following article by Microsoft https://learn.microsoft.com/en-us/azure/azure-arc/servers/arc-gateway?tabs=portal.
Troubleshoot
Force the Azure Connected Machine agent to connect to Azure Arc
On Windows restart the Azure Hybrid Instance Metadata Service.
data:image/s3,"s3://crabby-images/e9ec9/e9ec908f7fb68a3a4548af3c680f20fe400f7e50" alt=""
On Linux restart the himdsd.service.
# systemctl restart himdsd.service
data:image/s3,"s3://crabby-images/f6a7b/f6a7b5a0f7abcf76ba18d23dd8c4034dd7fd3b5d" alt=""
About how to configure a S2S IPsec VPN Tunnel between on-premise and Azure, you can read my following posts.
Links
Use Azure Private Link to securely connect servers to Azure Arc
https://learn.microsoft.com/en-us/azure/azure-arc/servers/private-link-securityAzure DNS Private Resolver endpoints and rulesets
https://learn.microsoft.com/en-us/azure/dns/private-resolver-endpoints-rulesetsQuickstart: Create an Azure DNS Private Resolver using the Azure portal
https://learn.microsoft.com/en-us/azure/dns/dns-private-resolver-get-started-portalAzure Private Endpoint DNS integration
https://learn.microsoft.com/en-us/azure/private-link/private-endpoint-dns-integration.ms ccTLD Domain
https://en.wikipedia.org/wiki/.msazcmagent CLI reference
https://learn.microsoft.com/en-us/azure/azure-arc/servers/azcmagentConnect hybrid machines to Azure using a deployment script
https://learn.microsoft.com/en-us/azure/azure-arc/servers/onboard-portal#install-and-validate-the-agent-on-linux