Intro
Lately, I have been looking at Azure dashboards to provide a quick overview of services running in Azure. In this post, I want to show you how to create a dashboard showing the state of virtual machines, S2S VPN connections, and network peerings.
data:image/s3,"s3://crabby-images/cd6b9/cd6b9ce9ed552202fd863a542ae2d758afcc33e2" alt=""
Azure Resource Graph Explorer (RGE)
The base for the dashboards in this post is RGE. I will create some queries to generate the data I want to show on my dashboard. RGE is a Kusto Query Language tool that allows you to query your Azure resource with lightning speed. You could find all the information with PowerShell or another tool, but using RGE is a lot faster. One important thing to remember is that RGE queries are case-sensitive, so check the casing if your results are not as expected. To query my VMs, I need to find which table contains information about VMs. I can see this table by going to a VM in the portal and selecting “Properties.” The portal will now show me the “Resource ID,” In that context, I can find the table name right after “/providers/.” In this case, the table I need to query will be “Microsoft.Compute/VirtualMachines.”
data:image/s3,"s3://crabby-images/ce7ef/ce7ef1aa6af754e292150a77fa144a94183919f0" alt=""
To open RGE, I will use the search field and search for it.
data:image/s3,"s3://crabby-images/04b38/04b38f7b9955793fcd1fd0ba0f859fa1fab2e7e7" alt=""
For this blog post, all the queries I will make will be against the category called “resources.”
data:image/s3,"s3://crabby-images/f51b3/f51b317e62a029dd14c89af92dbb018a3355435b" alt=""
Virtual machine dashboard
I know that the VM is a resource, so under the RGE, I click and then expand the “resources” table. When I click the table, it will be pasted into the query window.
data:image/s3,"s3://crabby-images/393a1/393a1ac68f3b1a68efc9b8c5eff3dba5d38286c5" alt=""
I can now scroll down to “microsoft.compute/virtualmachines,” as this was the table I found in the previous section. I click on the table, and it will be pasted into the query window.
data:image/s3,"s3://crabby-images/de45a/de45aab8690a159653d8a39fe24486942efbb877" alt=""
I can run the query and get a list of my VMs.
data:image/s3,"s3://crabby-images/35738/3573806c1986e0cd08e93a14a1885776ea3b7b6e" alt=""
I can now scroll to the right and find the “See details” link. If I click on the link, I can see more information about my VM. If I scroll down to the “extended” section, I can see that the “instanceView” has information on the power state of the VM, and this is the information I want to show in my dashboard.
data:image/s3,"s3://crabby-images/8c457/8c457294efa219e9a9dee437ff8ba86b4297e1db" alt=""
With this information, I can now update my query to ask for the specific items I want to show in my dashboard. I want to keep it simple, so I only wish to add the name and the power state of the VM. I use the tostring function and add the path to the information I need.
resources
| where type == "microsoft.compute/virtualmachines"
| project name,tostring(properties.extended.instanceView.powerState.displayStatus)
When I run the query, it will return the result below.
data:image/s3,"s3://crabby-images/410a0/410a0fa6ab8226b22ffa424b6453bde6fab29c70" alt=""
I’m not too fond of the column name for the power state, so I will modify my query a bit to return something that makes more sense.
resources
| where type == "microsoft.compute/virtualmachines"
| project Name = name, PowerState = tostring(properties.extended.instanceView.powerState.displayStatus)
data:image/s3,"s3://crabby-images/73324/73324c9f97d029351596bd9402f5d27a29e21ec7" alt=""
I will save my query to reuse it later on if needed.
data:image/s3,"s3://crabby-images/5ae90/5ae907ba72842176f856c79bde77b0adc5b8b420" alt=""
I will now pin the query to a new dashboard. I do this by clicking on “Pin to dashboard,” selecting “Create new,” I chose a “Private” dashboard and named it “Service overview.” The last thing to do is click on “Create and pin.”
data:image/s3,"s3://crabby-images/dd898/dd898285f70bb5e14bc5b51091491e86106a7d79" alt=""
I browse to dashboards and select the “Service overview” I just created, and it now shows me the status of my virtual machines on a dashboard.
data:image/s3,"s3://crabby-images/59c4e/59c4e909adc3f7ed901592b5cec0726c62597168" alt=""
I want to add another VM view to my dashboard, so I will create a summary of my VMs with power state and create a donut chart in my query. The process is the same as before, so I have pasted the new query below.
resources
| where type == "microsoft.compute/virtualmachines"
| summarize count() by PowerState= tostring(properties.extended.instanceView.powerState.displayStatus)
To make it a donut chart, I can go to the “Charts” section under my query and select “Donut chart.”
data:image/s3,"s3://crabby-images/e2efe/e2efedc368f755ca0b3588df2d9c2a072f861588" alt=""
I will save the query and then click on “Pin to dashboard,” select “Existing,” select the “Service overview” dashboard I created earlier and click on “Pin” to add it to the dashboard.
data:image/s3,"s3://crabby-images/53e4f/53e4f4903b4ee97fe35c38bb9b101a489c040df7" alt=""
I can now see both the list and chart on my dashboard. I have edited my dashboard to arrange the information side by side and changed the size to 6x4.
data:image/s3,"s3://crabby-images/3d106/3d106c5580963de0f18a68a03710adb1904e364a" alt=""
VPN connections
The process of adding the VPN connection is the same as the VMs, so I have only pasted in the Kusto Query needed to create the information for the dashboard.
List for VPN Connection status.
resources
| where type == "microsoft.network/connections"
| project name, Status = tostring(properties.connectionStatus)
Chart for VPN connection status.
resources
| where type == "microsoft.network/connections"
| summarize count() by ConnectionStatus = tostring(properties.connectionStatus)
I added it to the dashboard.
data:image/s3,"s3://crabby-images/80b83/80b83041d27518d3af933d142ba99068b8145cf9" alt=""
Virtual Network Peering
I also wanted to check my vNet peerings, so I have added the Kusto queries below.
List of vNet peerings.
resources
| where type =~ 'microsoft.network/virtualNetworks'
| mv-expand peering=properties.virtualNetworkPeerings
| where peering.properties.peeringState == "Connected"
| project name, PeeringName = tostring(peering.name),Status = tostring(peering.properties.peeringState), RemoteAddressSpace = tostring(peering.properties.remoteAddressSpace.addressPrefixes)
Chart for vNet peerings.
resources
| where type =~ 'microsoft.network/virtualNetworks'
| mv-expand peering=properties.virtualNetworkPeerings
| where peering.properties.peeringState == "Connected"
| project name, PeeringName = tostring(peering.name),Status = tostring(peering.properties.peeringState), RemoteAddressSpace = tostring(peering.properties.remoteAddressSpace.addressPrefixes)
| summarize count() by Status
I added it to the dashboard.
data:image/s3,"s3://crabby-images/d6634/d6634a706dc48c63d2631114f2c89bb46f37edfe" alt=""
Summary
With these services added to my dashboard, I am happy with it for now. I will probably add more services later, like, for instance, my App Services, but that will be a later post if so. As this article has shown, it is easy to create these dashboards, which adds value. I don’t have to click around the portal to find my Azure resource health information. It is right there in front of me.
I hope this post was helpful.
If you have questions or feedback, reach out to me.