grafana/devenv
ismail simsek b532df36c4
Explore Metrics: Support prometheus utf8 metrics names and labels (#98285)
* utf8 metrics for prometheus devenv

* introduce utf8 support

* completions and suggestions

* don't wrap the utf8 label in quotes

* linting

* support utf8 labels and metrics on visual query builder

* lint

* update raw view for utf8 metric syntax

* betterer

* support utf8 metric names in explore metrics

* utf8 support in grouop by

* utf8 support in label break down

* support series endpoint

* support series endpoint

* support series endpoint

* Explore metrics: Utf8 support in Explore metrics with OTel experience enabled (#98707)

* betterer

---------

Co-authored-by: Brendan O'Handley <brendan.ohandley@grafana.com>
2025-01-16 16:49:06 +02:00
..
bulk-dashboards Devenv: Longer provisioning update intervals (#88623) 2024-06-04 11:00:23 +02:00
bulk-folders Fix(devenv): use #!/usr/bin/env for bash scripts (#95117) 2024-10-22 10:20:33 +02:00
dev-dashboards Transformations: Preserve base threshold when using Config from query results (#96781) 2024-11-21 12:46:29 -06:00
dev-dashboards-without-uid DevEnv: Fix missing commas in dashboards (#77359) 2023-10-30 14:18:33 +01:00
docker Explore Metrics: Support prometheus utf8 metrics names and labels (#98285) 2025-01-16 16:49:06 +02:00
jsonnet Plugin extensions: Add e2e tests (#89048) 2024-06-14 13:41:17 +02:00
local_cdn Build: Fix failing CSS asset paths (#95380) 2024-10-25 13:45:44 +02:00
local-npm Build: Improve NPM publishing (#65171) 2023-04-18 10:19:37 +02:00
alert_rules.yaml ReturnToPrevious: Add e2e test (#83115) 2024-03-21 09:05:51 +01:00
create_docker_compose.sh Fix(devenv): use #!/usr/bin/env for bash scripts (#95117) 2024-10-22 10:20:33 +02:00
dashboards.yaml Devenv: Longer provisioning update intervals (#88623) 2024-06-04 11:00:23 +02:00
datasources_docker.yaml Elasticsearch: Deprecate the usage of the database field in provisioning (#66828) 2023-04-19 14:13:53 +01:00
datasources.yaml Caching: specify uid for cloudwatch datasource (#97041) 2024-12-17 10:01:43 +00:00
plugins.yaml Plugin Extensions: Require meta-data to be defined in plugin.json during development mode (#93429) 2024-10-04 08:41:26 +02:00
README.md Chore: vscode devenv cleanup (#94290) 2024-10-14 16:37:04 +03:00
setup.sh Fix(devenv): use #!/usr/bin/env for bash scripts (#95117) 2024-10-22 10:20:33 +02:00

Set up your development environment

This folder contains useful scripts and configuration so you can:

  • Configure data sources in Grafana for development.
  • Configure dashboards for development and test scenarios.
  • Set up an SMTP Server + Web Interface for viewing and testing emails.
  • Create docker-compose file with databases and fake data.

Install Docker

Grafana uses Docker to make the task of setting up databases a little easier. If you do not have it already, make sure you install Docker before proceeding to the next step.

Developer dashboards and data sources

To setup developer dashboards and data sources

./setup.sh

To remove the setup developer dashboards and data sources

./setup.sh undev

After restarting the Grafana server, there should be a number of data sources named gdev-<type> provisioned as well as a dashboard folder named gdev dashboards. This folder contains dashboard and panel features tests dashboards.

Please update these dashboards or make new ones as new panels and dashboards features are developed or new bugs are found. The dashboards are located in the devenv/dev-dashboards folder.

docker-compose with databases

This command creates a docker-compose file with specified databases configured and ready to run. Each database has a prepared image with some fake data ready to use. For available databases, see docker/blocks directory. Notice that for some databases there are multiple images with different versions. Some blocks such as slow_proxy_mac or apache_proxy_mac are specifically for Macs.

make devenv sources=influxdb,prometheus,elastic5

Some of the blocks support dynamic change of the image version used in the Docker file. The signature looks like this:

make devenv sources=postgres,auth/openldap,grafana postgres_version=9.2 grafana_version=6.7.0-beta1

Notes per block

Grafana

The grafana block is pre-configured with the dev-datasources and dashboards.

Tempo

The tempo block runs loki and prometheus as well and should not be ran with prometheus as a separate source. You need to install a docker plugin for the self logging to work, without it the container won't start. See https://grafana.com/docs/loki/latest/clients/docker-driver/#installing for installation instructions.

Jaeger

Jaeger block runs both Jaeger and Loki container. Loki container sends traces to Jaeger and also logs its own logs into itself so it is possible to setup derived field for traceID from Loki to Jaeger. You need to install a docker plugin for the self logging to work, without it the container won't start. See https://grafana.com/docs/loki/latest/clients/docker-driver/#installing for installation instructions.

Graphite

version source name graphite-web port plaintext port pickle port
1.1 graphite 8180 2103 2103
1.0 graphite1 8280 2203 2203
0.9 graphite09 8380 2303 2303

MailDev

MailDev block runs an SMTP server and a web UI to test and view emails. This is useful for testing your email notifications locally.

Make sure you configure your .ini file with the following settings:

[smtp]
enabled = true
skip_verify = true
host = "localhost:1025"

You can access the web UI at http://localhost:12080/#/

Debugging setup in VS Code

An example of launch.json is provided in .vscode/launch.json. It basically does what Makefile and .bra.toml do. The 'program' field is set to the folder name so VS Code loads all *.go files in it instead of just main.go.

Troubleshooting

Containers that read from log files fail to start (Mac OS)

If you are running Mac OSX, containers that read from the log files (e.g. Telegraf, Fileabeat, Promtail) can fail to start. This is because the default Docker for Mac does not have permission to create grafana folder at the /var/log location, as it runs as the current user. To solve this issue, manually create the folder /var/log/grafana, then start the containers again.

sudo mkdir /var/log/grafana