Datasources

Datasource plugins enables people to develop plugins for any database that communicates over http. Its up to the plugin to transform the data into time series data so that any grafana panel can then show it.

Datasource development

Our goal is not to have a very extensive documentation but rather have actual code that people can look at. An example implementation of a datasource can be found in this example datasource repo

To interact with the rest of grafana the plugins module file can export 5 different components.

  • Datasource (Required)
  • QueryCtrl (Required)
  • ConfigCtrl (Required)
  • AnnotationsQueryCtrl

Plugin json

There are two datasource specific settings for the plugin.json

  1. "metrics": true,
  2. "annotations": false,

These settings indicates what kind of data the plugin can deliver. At least one of them have to be true

Datasource

The javascript object that communicates with the database and transforms data to times series.

The Datasource should contain the following functions:

  1. query(options) //used by panels to get data
  2. testDatasource() //used by datasource configuration page to make sure the connection is working
  3. annotationQuery(options) // used by dashboards to get annotations
  4. metricFindQuery(options) // used by query editor to get metric suggestions.

testDatasource

When a user clicks on the Save & Test button when adding a new data source, the details are first saved to the database and then the testDatasource function that is defined in your data source plugin will be called. It is recommended that this function makes a query to the data source that will also test that the authentication details are correct. This is so the data source is correctly configured when the user tries to write a query in a new dashboard.

Query

Request object passed to datasource.query function:

  1. {
  2. "range": { "from": "2015-12-22T03:06:13.851Z", "to": "2015-12-22T06:48:24.137Z" },
  3. "interval": "5s",
  4. "targets": [
  5. { "refId": "B", "target": "upper_75" },
  6. { "refId": "A", "target": "upper_90" }
  7. ],
  8. "format": "json",
  9. "maxDataPoints": 2495 //decided by the panel
  10. }

There are two different kinds of results for datasources; time series and table. Time series is the most common format and is supported by all datasources and panels. Table format is only supported by the InfluxDB datasource and table panel. But we might see more of this in the future.

Time series response from datasource.query. An array of:

  1. [
  2. {
  3. "target":"upper_75",
  4. "datapoints":[
  5. [622, 1450754160000],
  6. [365, 1450754220000]
  7. ]
  8. },
  9. {
  10. "target":"upper_90",
  11. "datapoints":[
  12. [861, 1450754160000],
  13. [767, 1450754220000]
  14. ]
  15. }
  16. ]

Table response from datasource.query. An array of:

  1. [
  2. {
  3. "columns": [
  4. {
  5. "text": "Time",
  6. "type": "time",
  7. "sort": true,
  8. "desc": true,
  9. },
  10. {
  11. "text": "mean",
  12. },
  13. {
  14. "text": "sum",
  15. }
  16. ],
  17. "rows": [
  18. [
  19. 1457425380000,
  20. null,
  21. null
  22. ],
  23. [
  24. 1457425370000,
  25. 1002.76215352,
  26. 1002.76215352
  27. ],
  28. ],
  29. "type": "table"
  30. }
  31. ]

Annotation Query

Request object passed to datasource.annotationQuery function:

  1. {
  2. "range": { "from": "2016-03-04T04:07:55.144Z", "to": "2016-03-04T07:07:55.144Z" },
  3. "rangeRaw": { "from": "now-3h", to: "now" },
  4. "annotation": {
  5. "datasource": "generic datasource",
  6. "enable": true,
  7. "name": "annotation name"
  8. }
  9. }

Expected result from datasource.annotationQuery:

  1. [
  2. {
  3. "annotation": {
  4. "name": "annotation name", //should match the annotation name in grafana
  5. "enabled": true,
  6. "datasource": "generic datasource",
  7. },
  8. "title": "Cluster outage",
  9. "time": 1457075272576,
  10. "text": "Joe causes brain split",
  11. "tags": ["joe", "cluster", "failure"]
  12. }
  13. ]

QueryCtrl

A JavaScript class that will be instantiated and treated as an Angular controller when the user edits metrics in a panel. This class has to inherit from the app/plugins/sdk.QueryCtrl class.

Requires a static template or templateUrl variable which will be rendered as the view for this controller.

ConfigCtrl

A JavaScript class that will be instantiated and treated as an Angular controller when a user tries to edit or create a new datasource of this type.

Requires a static template or templateUrl variable which will be rendered as the view for this controller.

AnnotationsQueryCtrl

A JavaScript class that will be instantiated and treated as an Angular controller when the user choose this type of datasource in the templating menu in the dashboard.

Requires a static template or templateUrl variable which will be rendered as the view for this controller. The fields that are bound to this controller are then sent to the Database objects annotationQuery function.