Azure PaaS Blog articles

Azure PaaS Blog articles

https://techcommunity.microsoft.com/t5/azure-paas-blog/bg-p/AzurePaaSBlog

Azure PaaS Blog articles

Retrieve Cloud Service Extended Support detail via PowerShell

Published

Retrieve Cloud Service Extended Support detail via PowerShell

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: 

  1. Use command Connect-AzAccount to login
  2. 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 
  3. 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 commandExample 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: 

  1. Use command Connect-AzAccount to login 
  2. 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 
  3. 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 requestExample 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 CSESExample 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/osVersionExample 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 nameExample 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. 

Continue to website...

More from Azure PaaS Blog articles

Related Posts