In continuation with Part 1 of the series, in this post, we will discuss CMG App-Registrations.
Once the Installation Wizard for the CMG is complete, the Service Connection Point creates a thread for the Cloud Manager, which is observable in the CloudMgr.log. Our server app establishes a connection to Azure and applies the ARM Template to the Resource Group based on the wizard properties provided which deploys the following Azure resources:
The virtual machines in the scale set are configured using PowerShell Desired State Configuration. This configuration is found in the Installation directory of ConfigMgr ("<ConfigMgr-Installalocation>\inboxes\cloudmgr.box\cmgdsc.zip"), is uploaded to the Storage Account and applied from there. This configuration sets up the WebServer, installs additional WebComponents, removes legacy Crypto-Provider, disables RC4, and performs cleanup tasks for Internet Information Service.
If you look at the Azure Resource Visualizer, it shows the following configuration:
Virtual Machine Scale Set
The VMSS configuration includes the number of instances, their state, the operating system, and extensions like PowerShell DSC. Although VMSS supports auto scaling which includes adding or removing virtual machines based on usage, this isn’t supported by ConfigMgr. This is because configuration changes made outside of the ConfigMgr API aren't supported, as ConfigMgr isn't aware of such changes, potentially leading to issues.
With the creation of the VMSS, an Enterprise Application Managed Identity is also created for accessing the key vault.
Key Vault
Inside the Key Vault for the CMG’s VMSS, there are two secrets stored:
Additionally, we store the certificate for the CMG.
By default, only two applications have access to the key vault: our WebApp and the managed identity of the scale set.
Load Balancer
The Load Balancer distributes traffic among multiple virtual machine instances within the CMG. It’s configured with a front end IP configuration linked to the public address and three rules:
Front End Port |
Back End Port |
Service |
50000 |
3389 |
RDP |
10124 |
8443 |
Custom / CMG-Channel-Traffic |
The Remote Desktop Protocol is pre-created and used in combination with an Azure Bastion avoiding external port exposure.
One of our peers in Ireland wrote one article specific to this Port 8443 – which you will also find in the Network Security Groups: Cloud Management Gateway - Inbound Rule for Port 8443 - Microsoft Community Hub.
Network Security Groups
Apart from Default Rules for Inbound/Outbound Security, there are two allow rules for inbound traffic:
Name |
Port |
Protocol |
Source |
Destination |
Action |
webHttpsRule |
443 |
TCP |
INTERNET |
10.0.0.0/24 |
Allow |
webHttps8443Rule |
8443 |
TCP |
INTERNET |
10.0.0.0/24 |
Allow |
The virtual subnet is solely associated with this resource group’s Network Security Group (NSG).
Public IP Adress
The Public IP Address serves its obvious purpose. Notably, the IP Address Assignment is static, ensuring the IP Address is retained unless this Resource is deleted. For details on Azure public IP addresses, see Create, change, or delete an Azure public IP address - Azure Virtual Network | Microsoft Learn.
Virtual Network
As outlined above, there is a single IP-Subnet 10.0.0.0/24 associated with the Scale Set NSG.
Storage Account
Here we upload and store all ConfigMgr content distributed to the CMG’s cloud storage to Azure blob storage.
We also create tables within Azure the Azure storage account for CMG logging, audit and configuration purposes.
Defender for Cloud Recommendations
Security is vital for organizations – and of course we need to address those concerns. For Instance, if you use at the Defender for Cloud recommendations you will see the following advices for a CMG:
As mentioned earlier, the CMG is a SaaS utilizing PaaS components, and modifications are not supported outside the Configuration Manager API. The following comments address each of the items called out in the screenshot above.
We hope this Blogpost provides a better understanding of the CMG, assisting ConfigMgr Admins in addressing queries from their Azure & Security Teams.
Disclaimer
The sample scripts are not supported under any Microsoft standard support program or service. The sample scripts are provided AS IS without warranty of any kind. Microsoft further disclaims all implied warranties including, without limitation, any implied warranties of merchantability or of fitness for a particular purpose. The entire risk arising out of the use or performance of the sample scripts and documentation remains with you. In no event shall Microsoft, its authors, or anyone else involved in the creation, production, or delivery of the scripts be liable for any damages whatsoever (including, without limitation, damages for loss of business profits, business interruption, loss of business information, or other pecuniary loss) arising out of the use of or inability to use the sample scripts or documentation, even if Microsoft has been advised of the possibility of such damages.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.