Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to query for "all but one" in graphite/grafana

I'm playing with grafana and I want to create a panel where I compare data from one app server against the average of all the others except that one. Something like:

apps.machine1.someMetric
averageSeries(apps.*.not(machine1).someMetric)

Can that be done? How?

like image 448
sprugman Avatar asked Dec 11 '15 00:12

sprugman


2 Answers

Sounds like you want to filter a seriesList, you an do that inclusively using the 'grep' function or exclusively using the 'exclude' function

exclude(apps.machine*.someMetric,"machine1")

and pass that into averageSeries

averageSeries(exclude(apps.machine*.someMetric,"machine1"))

You can read more about those functions here: http://graphite.readthedocs.io/en/latest/functions.html#graphite.render.functions.exclude

like image 55
Scott Avatar answered Nov 12 '22 18:11

Scott


After reading the Graphite URL API docs section about wildcard paths I don't think there is any "all but one" target query. However if you don't have many machines you can list all them but the excluded one in your query:

apps.machine1.someMetric
averageSeries(apps.{machine2,machine3,machine4,machine5}.someMetric)

Or use a character range:

apps.machine1.someMetric
averageSeries(apps.machine[2-5].someMetric)
like image 6
dukebody Avatar answered Nov 12 '22 16:11

dukebody