Extended grafana dashboard to display dimensions.
Before the dimensions on the Metrics tab were hardcoded, now they are read from the URL and are filtered based on the 'dim_' prefix. Furthermore, modified the URL for the Graph Metrics button to append dim_ prefix for dimensions. Change-Id: I5f71b17ffba48f2cfbad9d299285b6deb9dccd6f Story: 2001179 Task: 4914
This commit is contained in:
parent
9dc87decbf
commit
33a98e4381
@ -19,6 +19,22 @@ var dashboard;
|
|||||||
// All url parameters are available via the ARGS object
|
// All url parameters are available via the ARGS object
|
||||||
var ARGS;
|
var ARGS;
|
||||||
|
|
||||||
|
// Setup the metric dimensions.
|
||||||
|
var dimensions = [];
|
||||||
|
|
||||||
|
for (var key in ARGS) {
|
||||||
|
var isDimParam = key.startsWith("dim_");
|
||||||
|
if (isDimParam) {
|
||||||
|
var value = ARGS[key];
|
||||||
|
var dim = {
|
||||||
|
"key": key.substring(4),
|
||||||
|
"value": value
|
||||||
|
};
|
||||||
|
dimensions.push(dim);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Intialize a skeleton with nothing but a rows array and service object
|
// Intialize a skeleton with nothing but a rows array and service object
|
||||||
dashboard = {
|
dashboard = {
|
||||||
rows : [],
|
rows : [],
|
||||||
@ -38,7 +54,6 @@ dashboard.time = {
|
|||||||
var rows = 1;
|
var rows = 1;
|
||||||
var metricName = '';
|
var metricName = '';
|
||||||
var hostname = '';
|
var hostname = '';
|
||||||
var region = '';
|
|
||||||
|
|
||||||
if(!_.isUndefined(ARGS.rows)) {
|
if(!_.isUndefined(ARGS.rows)) {
|
||||||
rows = parseInt(ARGS.rows, 10);
|
rows = parseInt(ARGS.rows, 10);
|
||||||
@ -52,10 +67,6 @@ if(!_.isUndefined(ARGS.hostname)) {
|
|||||||
hostname = ARGS.hostname;
|
hostname = ARGS.hostname;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!_.isUndefined(ARGS.region)) {
|
|
||||||
region = ARGS.region;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var i = 0; i < rows; i++) {
|
for (var i = 0; i < rows; i++) {
|
||||||
|
|
||||||
dashboard.rows.push({
|
dashboard.rows.push({
|
||||||
@ -72,16 +83,7 @@ for (var i = 0; i < rows; i++) {
|
|||||||
{
|
{
|
||||||
"aggregator": "avg",
|
"aggregator": "avg",
|
||||||
"alias": hostname,
|
"alias": hostname,
|
||||||
"dimensions": [
|
"dimensions": dimensions,
|
||||||
{
|
|
||||||
"key": "hostname",
|
|
||||||
"value": hostname
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"key": "region",
|
|
||||||
"value": region
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"metric": metricName,
|
"metric": metricName,
|
||||||
"period": "300",
|
"period": "300",
|
||||||
}
|
}
|
||||||
@ -94,5 +96,4 @@ for (var i = 0; i < rows; i++) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return dashboard;
|
return dashboard;
|
||||||
|
@ -167,7 +167,7 @@ class GraphMetric(tables.LinkAction):
|
|||||||
dimensions = datum['metrics'][0].get('dimensions', {})
|
dimensions = datum['metrics'][0].get('dimensions', {})
|
||||||
query = "?metric=%s" % metric
|
query = "?metric=%s" % metric
|
||||||
for key, value in dimensions.iteritems():
|
for key, value in dimensions.iteritems():
|
||||||
query += "&%s=%s" % (key, value)
|
query += "&dim_%s=%s" % (key, value)
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
# Catches case where Grafana 2 is not enabled.
|
# Catches case where Grafana 2 is not enabled.
|
||||||
name = datum['metrics'][0]['name']
|
name = datum['metrics'][0]['name']
|
||||||
|
Loading…
Reference in New Issue
Block a user