This blog is mainly about how to retrieve the CSES configuration via PowerShell and REST API. It will cover the following sections:
- PowerShell command to get the CSES configuration
- PowerShell to send out REST API request to get the CSES configuration
- Sample to retrieve OS Family, OS Version and any other data
Prerequisites
No matter PowerShell command or Rest API request will be used to get the information, the PowerShell Azure Az module is necessary. For the installation details, please refer to this document.
PowerShell command to get the CSES configuration
To use Get-AzCloudService (Az.CloudService) | Microsoft Learn to get the CSES configuration data, we can follow these steps:
- Use command Connect-AzAccount to login
- Use command Get-AzCloudService to get the full picture of your CSES resource and save it into a PowerShell variable such as $cses in the following example
- Convert the configuration of the CSES into XML format.
The used commands will be:
Connect-AzAccount
$cses = Get-AzCloudService -ResourceGroupName “xxx” -CloudServiceName “xxx”
[xml]$xml = $cses.Configuration
Example of PowerShell command
PowerShell to send out REST API call to get the CSES configuration
To use Cloud Services - Get - REST API (Azure Compute) | Microsoft Learn to get the CSES configuration data by sending out REST API call in PowerShell, we can follow these steps:
- Use command Connect-AzAccount to login
- Use command Invoke-AzRestMethod to send out the REST API call. The path in the command will be the same for every user except the value such as your own subscription ID, resource group name and CSES resource name. Once we get the response, we can use some additional PowerShell function like convertfrom-json to proceed the data and then save it into a PowerShell variable such as $csesapi in the example
- Convert the configuration of the CSES into XML format
The used commands will be:
Connect-AzAccount
$csesapi = (Invoke-AzRestMethod -Path "/subscriptions/{subscription-id}/resourceGroups/{resource-group-name}/providers/Microsoft.Compute/cloudServices/{CSES-resource-name}?api-version=2021-03-01").Content | convertfrom-json
[xml]$xml = $csesapi.properties.configuration
Example of REST API request
Sample about how to get OS Family, OS Version and any other data
No matter PowerShell command or REST API is used, with above instruction, the $xml from both ways will be the same.
Basically, this is how my example CSES configuration data looks like:
Example of configuration data of CSES
The $xml is the whole configuration file in XML format. In order to get the data, such as osFamily, osVersion or VirtualNetworkSite, following the construction of this XML file to add related name to identify the data of which level is needed will be enough.
For example, for osVersion/osFamily, the path to it will be ServiceConfiguration -> osVersion/osFamily. So the expression to use in PowerShell to get the data will be:
$xml.ServiceConfiguration.osVersion / $xml.ServiceConfiguration.osFamily
Example expression for osFamily/osVersion
And for the VirtualNetworkSite, the path to it will be ServiceConfiguration -> NetworkConfiguration -> VirtualNetworkSite -> name. So the expression to use in PowerShell to get the data will be:
$xml.ServiceConfiguration.NetworkConfiguration.VirtualNetworkSite.name
Example expression of Virtual Network name
Note: It’s possible that we have more than one role in our configuration, the expression to locate a role which is not the first role will be $xml.ServiceConfiguration.Role[1]. The number “1” here means the second role in the configuration data because this counter starts from 0. If there are two roles in same configuration data, the expression $xml.ServiceConfiguration.Role[1].Instances.count will be able to return how many instances there are for the second role.
Published Oct 13, 2022
Version 1.0JerryZhangMS
Microsoft
Joined October 19, 2020
Azure PaaS Blog
Follow this blog board to get notified when there's new activity