Skip to main content

Provisioning in Grafana

Daria Volkova
Creative Director at Volkov Labs, Grafana Champion

Provisioning is one step up from the primary Grafana mindset. It is optional, but I recommend investing some time in researching this topic since harnessing it will bring you smooth and speedy deployments.

What is provisioning

Simply put, provisioning is when you push configuration via JSON, YAML, and other files into a Grafana instance. In Grafana 9.5.1, you can push configuration for:

  • RBAC (role-based access control)
  • Alerting rules
  • Dashboards
  • Data sources
  • Alert notifies
  • Plugins (applications)

Since Grafana comprises many independent parts, what components can be provisioned might be confusing. The general rule of thumb is you can provision configurations. You must install all data sources and visualization panels outside the provisioning processes.

Provisioning in grand schema Grafana things.
Provisioning in grand schema Grafana things.

Explained in a nutshell

In most cases, provisioning is used to update production environments to subsequent versions.

  • You make all necessary changes in the development environment.
  • Prepare provision files based on changes.
  • Place updated configuration into the corresponding folders.

After restarting all involved in the upgrade production Grafana instances, all changes are in place. If you need to get back to the previous state(version), remove the new files and use the old ones instead. Version control is one of the provisioning advantages.

Below is the link to my YouTube video, where I explain provisioning and demonstrate some examples.

Basics, pitfalls, file examples in Windows and Docker Demo.

Alternatives

Grafana UI

There are two alternatives to provisioning. You can log in to every Grafana instance that needs to be updated and perform all modifications using UI. That does not sound productive, and I agree. This method is slow, prone to errors, and not scalable. Consider this method in the early stages of adopting Grafana.

HTTP API

The other method includes using HTTP API endpoints. Grafana provides a variety of API functions to work with its configuration. This method is the only choice in environments without access to the file system (for example, cloud).

Provisioning is one of the ways to move changes from Development to Production environment.
Provisioning is one of the ways to move changes from Development to Production environment.

Getting started

To get a good first glimpse of provisioning, find the provisioning folder under the conf directory. Grafana 9.5.1 contains six subfolders, each representing a Grafana component you can provision.

Every subfolder represents a component you can provision in Grafana.
Every subfolder represents a component you can provision in Grafana.

You can find a sample.yaml file in every subfolder, except for alerting. The files are provided as a starter, but I find them too generic and semi-useful. I hope your more profound experience leaves you with an opposite impression.

Do not let the file name 'sample' mislead you. Grafana checks for all YAML files regardless of their names.

File sample.yaml is located in the dashboard subfolder.
File sample.yaml is located in the dashboard subfolder.

By default, the provisioned dashboards are protected from any modifications made by users in UI. You can change that by using the allowUpdates parameter being set to true.

Dashboard

For provisioning a dashboard at minimum expect to have two files. One with the yaml extension and the other one with json extension.

File sample.yaml is an example of how to provision dashboards.
File sample.yaml is an example of how to provision dashboards.

The path option is where Grafana will look for dashboard JSON file descriptions. The folder is the corresponding folder in the Grafana UI.

Export

The easiest way to have a dashboard in a JSON file is to create a dashboard in one of the Grafana instances and then use the 'Export' functionality.

You can export for sharing externally with either YES or NO. The difference is for the external export all unique identifiers are going to be replaced with a variable. Those JSON files are good when you use Import functionality in UI.

For provisioning leave the default value for Export for sharing externally unchecked.

How to export Grafana dashboard in a JSON format for further provisioning.
How to export Grafana dashboard in a JSON format for further provisioning.

Data sources

You only can provision a data source if it already has been installed as a plugin.

Plugin installation should be done by other means not as part of provisioning.
Plugin installation should be done by other means not as part of provisioning.

Unfortunately and surprisingly, there is no UI functionality for exporting a data source configuration. You must create a YAML file for your data source from scratch.

This not-so-exciting fact leads to a sorrowful conclusion. There is no one solid approach to having such a file. I can share what we use for the PostgreSQL data source.

apiVersion: 1

datasources:
- name: Business Satellite
type: volkovlabs-grapi-datasource
access: proxy
uid: grapi
orgId: 1
version: 1
editable: true
jsonData:
url: http://localhost:3000
- name: Timescale
type: postgres
access: proxy
uid: timescale
orgId: 1
version: 1
editable: true
url: host.docker.internal:5432
user: postgres
jsonData:
postgresVersion: 1200
sslmode: disable
secureJsonData:
password: postgres

For all others, go into the 'Inspect' menu of your browser and then look at the Network tab. If nothing is shown, try to refresh the page.

Where to find some data source attributes to create your YAML file from scratch.
Where to find some data source attributes to create your YAML file from scratch.

Alert rule

Provisioning an alert rule should feel like a warm, gentle breeze if you are resourceful and persistent enough to get through the provisioning of a data source puzzle. After you create an alert rule, simply use the export button.

The export process has no parameters, and the file name is always the same - export.yaml. In case of multiple rules, you must rename each file according to your logic. That is the only hurdle in your provision of an alert path.

Examples

If you are like me, you prefer examples to theoretical templates. In that case, you are welcome to our GitHub organization, where you can find many sound actual provisioning files. We use them for developing and testing our maintained plugins.

The concept of Provisioning allows isolating the core Grafana from the numerous features that could be added and configured separately.

The particular beauty of such architecture shines in a robust version control process. However, there is no one industry-accepted best way of performing Provisioning. You will have to make many decisions on your own, conduct research and explore the try-and-error route.

Always happy to hear from you

Subscribe to our YouTube Channel and leave your comments.

  Become a sponsor