Consume API Endpoints in Grafana

Grafana is an awesome open source analytics & monitoring tool. In this guide, you'll learn how to create Grafana Dashboards and Alerts consuming Tinybird API Endpoints.

Prerequisites

This guide assumes you have a Tinybird Workspace with an active Data Source, Pipes, and at least one API Endpoint. You'll also need a Grafana account.

1. Install the Infinity plugin

Follow the steps in Grafana Infinity plugin installation.

2. Create a Grafana data source

Create a new Data Source using the Infinity plugin. Connections > Data sources > Add new data source > Infinity.

Edit the name and complete the basic setup:

Authentication: choose Bearer Token. Pick a token with access to all the needed endpoints or create different data sources per token. Feel free to also add a restrictive list of allowed hosts.

That's basically it, but it is a good practice to add a Health check with an endpoint that the Token has access to so you verify connectivity is OK.

3. Configure the Query in Grafana

Create a new Dashboard, edit the suggested Panel, and use the Data Source you just created.

For the example we'll consume the endpoint shown in this picture. A time series of sensor temperature and humidity readings.

So, the in the Query editor is:

  • Type: JSON
  • Parser: Backend (needed for alerting and JSON parsing)
  • Source: URL
  • Format: Table
  • Method: GET
  • URL: https://api.eu-central-1.aws.tinybird.co/v0/pipes/api_readings.json
  • Parsing options & Result fields > Rows/root: data Needed cause the Tinybird response includes metadata, data, statistics...
  • Parsing options & Result fields > Columns: add the needed fields, select types, and adjust time formats.

It is important to use the Backend Parser for the Alerts to work and for compatibility with the root and field selectors as mentioned in the plugin docs.

For the Time Formats you can use plugin options. By default it uses Default ISO so you can simply add formatDateTime(t,'%FT%TZ') as t to your Tinybird API Endpoint and don't need to configure the option in Grafana.

Save the dashboard and you should now be able to see a chart.

4. Using time ranges

When you have millions of rows it is better to filter time ranges in Tinybird than to retrieve all the data and filter later when showing the chart in Grafana. You will get faster responses and more efficient use of the resources.

Edit the Tinybird Pipe to accept start_ts and end_ts parameters.

%
SELECT formatDateTime(timestamp,'%FT%TZ') t, temperature, humidity 
FROM readings
{% if defined(start_ts) and defined(end_ts) %}
WHERE timestamp BETWEEN parseDateTimeBestEffort({{String(start_ts)}}) 
   AND parseDateTimeBestEffort({{String(end_ts)}})
{% end %}
ORDER BY t ASC

In the Query editor, next to URL, click on Headers, Request params and fill URL Query Params.

Use Grafana's global variables $__from and $__to defined with the time range selector at the top right od the dashboard.

As said, filtering helps to have more efficient dashboards, here you can see how using filters, the scan size decreases.

5. Dashboard variables

You can also define dashboard variables and use them in the query:

That will make it interactive:

Note you have to edit the Pipe:

%
SELECT formatDateTime(timestamp,'%FT%TZ') t,
{% if defined(magnitude) and magnitude != 'all' %}
{{column(magnitude)}}
{% else %}
temperature, humidity 
{% end %}
FROM readings
{% if defined(start_ts) and defined(end_ts) %}
WHERE timestamp BETWEEN parseDateTimeBestEffort({{String(start_ts)}}) 
   AND parseDateTimeBestEffort({{String(end_ts)}})
{% end %}
ORDER BY t ASC

6. Alerts

Infinity plugin supports alerting, so you can create your own rules. In this example alert triggers when temperature goes outside a defined range.

And this is what you will see in the dashboard.

Be sure to correctly set up notifications if needed.

Note

Note: a previous version of this guide referred to the JSON API plugin but it was migrated to using Infinity plugin since it is now the default supported one.