Grafana: Template Variables: Unterschied zwischen den Versionen

Aus Wiki-WebPerfect
Wechseln zu: Navigation, Suche
Zeile 1: Zeile 1:
 
= Troubleshooting =
 
= Troubleshooting =
== InfluxDB: "SHOW TAG VALUES" does not support a WHERE time clause ==
+
== InfluxDB Flux: The function "schema.tagValues()" does not support a "stop time range" and more filter options ==
 
=== Issue ===
 
=== Issue ===
'''If you use a InfluxDB Query "SHOW TAG VALUES.." it returns all possible values instead of the one present in the time period selected.''' <br>
+
'''If you use a the Flux function "schema.tagValues()" it returns all possible values instead of the ones present in the selected time period.''' <br>
 +
There is a open GitHub "Feature Request": https://github.com/influxdata/flux/issues/1071
 +
 
 +
 
 +
=== Workaround ===
 +
With the following workaround you are able to get Tag-Values with timerange selection and filter options:
 +
<pre>
 +
from(bucket: "<YOUR_BUCKET>")
 +
  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
 +
  |> filter(fn: (r) =>
 +
    r._measurement == "<YOUR_MEASUREMENT>"
 +
  )
 +
  |> keyValues(keyColumns: ["host"])
 +
  |> group()
 +
  |> keep(columns: ["host"])
 +
  |> distinct(column: "host")
 +
</pre>
 +
'''host''' = is the field I want in my Grafana template variable <br>
 +
'''v.timeRangeStart''' = Grafana start time <br>
 +
'''v.timeRangeStop''' = Grafana stop time <br>
 +
 
 +
 
 +
 
 +
 
 +
== InfluxDB InfluxQL: "SHOW TAG VALUES" does not support a WHERE time clause ==
 +
=== Issue ===
 +
'''If you use a InfluxDB Query "SHOW TAG VALUES.." it returns all possible values instead of the ones present in the selected time period.''' <br>
 
There is a open GitHub "Feature Request": https://github.com/influxdata/influxdb/issues/5668
 
There is a open GitHub "Feature Request": https://github.com/influxdata/influxdb/issues/5668
  

Version vom 20. Januar 2021, 15:11 Uhr

Troubleshooting

InfluxDB Flux: The function "schema.tagValues()" does not support a "stop time range" and more filter options

Issue

If you use a the Flux function "schema.tagValues()" it returns all possible values instead of the ones present in the selected time period.
There is a open GitHub "Feature Request": https://github.com/influxdata/flux/issues/1071


Workaround

With the following workaround you are able to get Tag-Values with timerange selection and filter options:

from(bucket: "<YOUR_BUCKET>")
  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
  |> filter(fn: (r) => 
    r._measurement == "<YOUR_MEASUREMENT>"
  )
  |> keyValues(keyColumns: ["host"])
  |> group()
  |> keep(columns: ["host"])
  |> distinct(column: "host")

host = is the field I want in my Grafana template variable
v.timeRangeStart = Grafana start time
v.timeRangeStop = Grafana stop time



InfluxDB InfluxQL: "SHOW TAG VALUES" does not support a WHERE time clause

Issue

If you use a InfluxDB Query "SHOW TAG VALUES.." it returns all possible values instead of the ones present in the selected time period.
There is a open GitHub "Feature Request": https://github.com/influxdata/influxdb/issues/5668


Workaround 1 - "Using fields" (recommended)

Using fields instead of tags. -> You have to write your "asset" data as fields.
This workaround is recommended because you can use functions like "DISTINCT" to get the unique value of a field (its like "dedup" in Splunk).

The InfluxQL looks like this:

SELECT DISTINCT("host") FROM "asset_powershell_direct" WHERE "time" > (${__from} * 1000000) - 24h AND "time" < (${__to} * 1000000)

host = is the field I want to limit by time and dedup the value
${__from} = Grafana "from" Timestamp variable (its uses the timepicker in the Grafana GUI). Because Grafana uses miliseconds and InfluxDB uses nanoseconds, you have to convert the value (* 1000000).
${__to} = Grafana "to" Timestamp variable (its uses the timepicker in the Grafana GUI). Because Grafana uses miliseconds and InfluxDB uses nanoseconds, you have to convert the value (* 1000000).
Because I want to search the data in minimum 24h back, I add "- 24h".


Workaround 2 - "Subquery"

Instead of using the following query:

SHOW TAG VALUES FROM "asset_powershell_direct" WITH KEY = "host"

use a subquery as a workaround:

SELECT "host" FROM (SELECT "<value>", "host" FROM "asset_powershell_direct" WHERE $timeFilter)

host = is the tag I want to limit by time
value = any Influx FieldKey (just needs to contain any value)
asset_powershell_direct = my example measurement-name