/sensu-influxdb-extension

A sensu handler for sending metrics to influxdb

Primary LanguageRubyOtherNOASSERTION

Requirements

influxdb ruby gem

Usage

The configuration options are pretty straight forward.

Metrics are inserted into the database with a table per check name. So if you're using the rabbitmq_overview_metrics plugin, you'd have a table in the defined database called rabbitmq_overview_metrics with the following columns:

  • host
  • metric.name1
  • metric.name2

Eg with the load-metrics.rb the following series would be generated:

┌────────────┬─────────────────┬────────────────────────────────────────┬──────────────┬───────────────┬──────────────────┐
│ time       │ sequence_number │ host                                   │ load_avg.one │ load_avg.five │ load_avg.fifteen │
├────────────┼─────────────────┼────────────────────────────────────────┼──────────────┼───────────────┼──────────────────┤
│ 1414548271 │ 209090001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.89          │ 0.53             │
│ 1414548261 │ 209080001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.89          │ 0.52             │
│ 1414548251 │ 209070001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.88          │ 0.52             │
│ 1414548241 │ 209060001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.88          │ 0.51             │
│ 1414548231 │ 209050001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.87          │ 0.51             │
│ 1414548221 │ 209040001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.87          │ 0.50             │
│ 1414548211 │ 209030001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.87          │ 0.50             │
│ 1414548201 │ 209020001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.86          │ 0.49             │
│ 1414548191 │ 209010001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.86          │ 0.49             │
│ 1414548181 │ 209000001       │ default-ubuntu-1404-i386.vagrantup.com │ 1.00         │ 0.85          │ 0.48             │
└────────────┴─────────────────┴────────────────────────────────────────┴──────────────┴───────────────┴──────────────────┘

Additionally a duration column would be present based on the time it took the check to run (this is gleaned from the sensu event data).

The value for metric is determined based on the value of strip_metric described below. You can query it like so:

an image

Extension not a handler

Note that the first push of this was a handler that could be called via pipe. This is now an actual extension that's more performant since it's actually in the sensu-server runtime. Additionally it's now using batch submission to InfluxDB by writing all the points for a given series at once.

Just drop the file in /etc/sensu/extensions and add it to your metrics configuration (/etc/sensu/conf.d/handlers/metrics.json:

{
  "handlers": {
    "metrics": {
      "type": "set",
      "handlers": [ "debug", "influxdb"]
    }
  }
}

Handler config (/etc/sensu/conf.d/influxdb.json)

{
  "influxdb": {
    "host": "localhost",
    "port": "8086",
    "user": "stats",
    "password": "stats",
    "database": "stats",
    "strip_metric": "somevalue"
  }
}

Host, port, user, password and database are pretty straight forward. strip_metric however might not be. This is used to "clean up" the data sent to influxdb. Normally everything sent to handlers is akin to the graphite/stats style:

something.host.metrictype.foo.bar

or

host.stats.something.foo.bar

Really the pattern is irrelevant. People have different tastes. Adding much of that data to the column name in InfluxDB is rather silly so strip_metric provides you with a chance to add a value that strips off everything up to (and including that value). This allows you to continue sending to graphite or statsd or whatever and still use this handler.

Using the examples above, if you set the strip_metric to host, then the column in InfluxDB would be called metrictype.foo.bar or stats.something.foo.bar. If you set the value to foo then the column would simply be called foo

Note that strip_metric isn't required.