Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implementing variables? #69

Open
PeterSurda opened this issue Mar 1, 2024 · 8 comments
Open

Implementing variables? #69

PeterSurda opened this issue Mar 1, 2024 · 8 comments
Assignees

Comments

@PeterSurda
Copy link

I'm trying to add a variable in grafana from TickTockDB data source, and it doesn't produce any results. I suspect the API to do this isn't implemented in TickTockDB. Do you know more about this? I don't know enough about what's missing and the design in order to implement it.

I use collectd to feed the data, but I put telegraf in the middle so that it can add the necessary tags (collectd's opentsdb output doesn't have tags). I want mainly a variable from the "host" tag, that would be adequate. Then I could select the host for a chart from a drop down menu.

@ylin30
Copy link
Collaborator

ylin30 commented Mar 1, 2024

@PeterSurda Do you refer to this? I created a custom variable 'HOST' with values (rpi4, raspberrypi, yi-Ideapad), and used it in query tag=value as host=$HOST.

image

image

@PeterSurda
Copy link
Author

PeterSurda commented Mar 1, 2024

You got it, except I want the variable values to be generated dynamically. In InfluxDB and QuestDB for example I can specify a query to produce the list:

  • InfluxDB: schema.tagValues(bucket: "mybucket", tag: "host")
  • QuestDB: SELECT host FROM df_value;

Grafana documentation says that for OpenTSDB the query is tag_values(host). However when applied on TickTockDB, it produces no results.

@PeterSurda
Copy link
Author

Well, what I could do is to have a process, run by a scheduler, that will run a query and use a grafana api call to populate the variable.

@ylin30
Copy link
Collaborator

ylin30 commented Mar 1, 2024

TT doesn't support APIs (e.g., tag_values(tag)) to retrieve values associated with a tag currently (v.0.12.1). The closest API is suggest?type=tagv&q=&max=1000 which returns all available values for all tags. The results can be filtered by keyword as specified as q=xxxx. Actually when you typed in the value textbox, you can see all unfiltered values for all tags (see the pic below).

To support retrieval of values of a tag, another index between a tag and its values is needed. We will put the functionality in the future list. Hope it is not a dealbreaker for you to use TT.

image

@PeterSurda
Copy link
Author

PeterSurda commented Mar 2, 2024

Thank you, I'll find some workaround. Even with this TT seems like the best choice so far (migrating away from rrdtool I also tried graphite carbon, influx, questdb).

This below for example is a quick PoC to produce a list of hosts for a specific chart that have data in the last minute:

curl -s 'http://localhost:6182/api/query?start=1m-ago&m=none:pybitmessagestatus_value.value\{type_instance=networkconnections,host=*\}'|jq -r '[.[].tags.host]|sort|unique|values'

@ylin30
Copy link
Collaborator

ylin30 commented Mar 2, 2024

Thank you, I'll find some workaround. Even with this TT seems like the best choice so far (migrating away from rrdtool I also tried graphite carbon, influx, questdb).

This below for example is a quick PoC to produce a list of hosts for a specific chart that have data in the last minute:

curl -s 'http://localhost:6182/api/query?start=1m-ago&m=none:pybitmessagestatus_value.value\{type_instance=networkconnections,host=*\}'|jq -r '[.[].tags.host]|sort|unique|values'

That's a smart workaround, even better than building an internal index (which is costly).

@PeterSurda
Copy link
Author

Now I just have to figure out how to do that inside grafana rather than in a shell.

@ytyou
Copy link
Owner

ytyou commented Dec 1, 2024

Grafana variables will be supported in our next release (v0.20.4). For example, you can edit any of your dashboards, define a variable called, say, 'host_var'. In the 'Query' section, put "tag_values(cpu_usr, host)". Then on your dashboard, you can add a tag filter whose value is the variable "$host_var". This allows you to use the drop-down menu at the top to switch to any hosts and display metrics for that particular host.

If you want this variable to work for ALL the metrics on the dashboard (not just 'cpu_usr' as in the above example), you can put "tag_values(*, host)" in the 'Query' section. It will work for any metrics on the dashboard.

@ytyou ytyou self-assigned this Dec 1, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants