vRealize Operations Header

How to build vROPs dashboard for tracking VM Growth over X days

I came across an interesting query on Reddit regarding vRealize Operations Manager (vROPs), summarised the query;

“Can I have a vROPs report/dashboard which shows me the storage usage by VMs over the past 3 days”

The short answer is yes, and I produced the following dashboard, views and report and uploaded to code.vmware.com for the post author to use.

Basic VM Growth Sparkline Dashboard VM Growth List

My dashboard has two elements to keep things simple;

  • A sparkline widget of VM’s storage used, the time frame show can be controlled in the dashboard view in the top-right hand corner
  • A list view of the VMs storage used covering a few metrics
    • Current Disk used
    • Disk Used (3 days ago)
    • Change of disk used (in GB)
    • Change of disk used (in %)

So, let’s look at how I created this.

Creating a Sparkline widget in the Dashboard

Create your dashboard, which will show you a blank canvas. Set the Dashboard name.

  • Drag the Sparkline Chart widget onto the canvas and resize as needed, you’ll see this option appear by hovering over the edge of the widget.
  • Click the pencil icon to edit the widget settings.

VM Growth Sparkline Chart Widget

Configure the Widget configuration. The most important options here are;

  • Self Provider – On
  • Show Object Name – On
  • Column Sequence – Label First

This means the widget will provide its own metric data to be displayed. It is not linked to other objects on the dashboard, as we are keeping this as a simple view.

The object name will be show as part of the label, with the label being shown first on the left, Sparkline on the right.

VM Growth Sparkline Chart Widget Configuration

Under the Input Data Tab, select All.

VM Growth Sparkline Chart Widget Input Data

Under Output data, we will select the metric we are interest in. Click the Green + symbol.

In the Add New Metrics pane, set the adapter type to “vCenter Adapter”, and select the Object Type as “Virtual Machine”. On the right-hand side, select under “Disk Space”, the metric “Virtual Machine used (GB)”, and click OK.

VM Growth Sparkline Chart Widget Output Data

You will see the metric added to the output data.

VM Growth Sparkline Chart Widget Output Data Metric Added

Under Output Filter, I have left this unconfigured in the dashboard you can download from the code.vmware.com website I listed at the start of the blog post. However, as an example, below is showing where I am filtering to show only VMs where disk space used is over 100GB.

VM Growth Sparkline Chart Widget Output Filter

For setting the time frame of this widget, you have two options.

  1. You can let the widget follow the overall time frame of the dashboard.
  2. You can configure the time frame used by widget regardless of the rest of the dashboard

To see the time setting used for the widget, you can hover of the top right-hand side of the widget pane, this will show you widget control options.

Click the Eye symbol. Then click the Calendar symbol. The first option is dashboard time, which will follow the master time setting, as highlighted by the red arrow.

Alternatively, you can statically set the time range from the options provided, or provide a custom range (purple arrow).

VM Growth Sparkline Chart Widget Setting time range

Final point to make on this widget. If you are interested in a particular virtual machine, you can double click on the Sparkline and this will show you more data for that particular object’s metric.

VM Growth Sparkline Chart Widget data viewVM Growth Sparkline Chart Widget data view metric deep dive

Creating a view which shows the change over a time frame

  • Create a new view, and provide a name
  • Select “list” for presentation
  • Under Subjects, select under vCenter Adapter > Virtual Machine

VM Growth List Create view set nameVM Growth List Create view Presentation List VM Growth List Create view Subjects vCenter Adapter Virtual Machine

  • Under Data, select Metrics > Disk Space > Virtual Machine Used (GB)
    • Drag over to the “data used in view” space

VM Growth List Create view Data Virtual Machine Used GB

I copied this metric across four times to create the columns needed, I will alter the configuration of each metric to display the data I need.

  • Disk Used (Current)

This metric stays the same, showing the current disk usage of the VM. I just altered the metric label.

  • Disk Used (3 days ago)

This metric is the same as the above, however I edit the configuration under transformation selecting the “expression option”. For the expression formula I simply choose first.

This configuration will show the metric that has first been recorded in this view. How do we ensure this shows the data from 3 days ago? Or 7 or 14 or 21, or whatever you want? We use Time Settings Tab to control this, which is discussed further on.

VM Growth List Create view Disk Used 3 Days ago Transformation expression first

  • Change (GB)

This metric gives us the change between todays value and the value as of 3 days ago (or whatever time frame you set)

Again, we are doing something similar as above by using the expression formula feature. The math is simple = Current (metric recorded) minus First (metric recorded).

VM Growth List Create view Disk Used 3 Days ago Transformation expression Current First

  • Change (%)

This last metric will use a slightly more advanced settings and calculations to give us the percentage of change.

I set the sort order to Descending, to show the largest value’s first. This will mean my view will show the VMs with the largest data growth over X days first.

Once again, I use a transformation expression to work out the percentage. Current value minus the First recorded value. Divide the output by the first value and multiple by 100 to give me the change in a percentage.

I then also set some metric colouring. So, if the percentage change is 30% or higher, it will show as red.

VM Growth List Create view Disk Used 3 Days ago Transformation expression Current First divide by first multiple by 100

  • Time Setting

So, the most important bit about this view is the time setting. So that these expressions show you the data growth over X days. It’s simple to do.

Click the Time Settings Tab. Select “Relative Date Range” and the number of days you are interested in.

VM Growth List Create view Time Settings Relative Data Range

  • Save your view

Finally, you should end up with something that looks like this when pointed at your vSphere World (or other filter source as needed).

VM Growth List

Summary

The main subject of this post is covering how to use the Transform with Expressions feature against a metric in a view within vROPs, marrying this to the time setting for that view.

Again, you can download all the files discussed to use in your vROPs environment here;

Regards

2 thoughts on “How to build vROPs dashboard for tracking VM Growth over X days

  1. This is very helpful glad I came across it. A few questions
    1) It looks like the time setting in the view is limited to one selection, but what about if I wanted multiple times, think, current, 3 days, 7 days ,14 days,etc.. Any way to adjust for that?

    2) How can I make the dashboard cluster specific? I have 40 clusters and 1500 vms, I only want to look at one cluster and the 50 vms within it

    3) when I attempt to import the report, I get “View with the same ID as ‘VM disk used’ already exists” Do I need to delete the View and only import the report?

    Sorry for all the questions,
    -Glenn

    1. Hi Glenn, sorry it took a while to reply.

      1. For this dashboard creation, you can clone the views, change the timeframes on them under time settings in the view. Then add to the dashboard. Alternatively you can set the view to take the time from the dashboard time setting (top right on the dashboard).

      2. If you want to make this cluster specific, you can add in an output filter to select the cluster you are interested in. Alternatively you can add an object picker to the dashboard, and link this to the view, so that the view chooses its inputs from there.

      3. Have you imported the view once before already? I’m sure there is no out of the box view with this name, but you could open up the view file and change the name in there before you import if needed. You’d then need to select the view again in the dashboard, as the name would be altered.

      Regards

      Dean

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.