Grafana - InfluxDB 2 - 标签/别名数据

The*_*Guy 15 influxdb grafana influxdb-2 flux-influxdb

我正在将面板从使用 SQL 语法(从 InfluxDB 版本 1.X)迁移到新的 influx 语法(InfluxDB 版本 2)。

数据标签存在问题。它包括我用来过滤它的属性。例如,如果我从包含 2 天的范围中选择数据,它会将数据拆分。请参阅下面的屏幕截图:

在此输入图像描述

这完全把图表弄乱了。基本代码如下所示:

from(bucket: "main")
  |> range(start: v.timeRangeStart, stop:v.timeRangeStop)
  |> filter(fn: (r) =>
      r._measurement == "POWER" and
      r._field == "value" and
      r.device == "living_room"
  )
  |> aggregateWindow(every: v.windowPeriod, fn: sum)
Run Code Online (Sandbox Code Playgroud)

显然应该只是“POWER”和“CURRENT”。

我尝试了十几种不同的方法,但无法提出可行的解决方案。

例如,如果我这样做:

from(bucket: "main")
  |> range(start: v.timeRangeStart, stop:v.timeRangeStop)
  |> filter(fn: (r) =>
      r._measurement == "POWER" and
      r._field == "value" and
      r.device == "living_room"
  )
  |> aggregateWindow(every: v.windowPeriod, fn: sum)
  |> map(fn: (r) => ({ POWER: r._value }))
Run Code Online (Sandbox Code Playgroud)

它说“数据没有时间字段”。

我也尝试过使用

from(bucket: "main")
  |> range(start: v.timeRangeStart, stop:v.timeRangeStop)
  |> filter(fn: (r) =>
      r._measurement == "POWER" and
      r._field == "value" and
      r.device == "living_room"
  )
  |> aggregateWindow(every: v.windowPeriod, fn: sum)
  |> yield(name: "POWER")
Run Code Online (Sandbox Code Playgroud)

那也不起作用。我尝试了很多其他的事情但没有成功。

我怎样才能解决这个问题?

The*_*Guy 20

经过几个小时的反复试验,我能够制定出一个可行的解决方案。我想其他用户可能会偶然发现同样的问题,因此我不会删除该问题,而是提供我的解决方案。

我基本上必须映射所需的字段和标签并分配所需的标签,而不仅仅是映射应显示的值(因为这样会丢失日期/时间数据)。

解决方案如下所示:

from(bucket: "main")
  |> range(start: v.timeRangeStart, stop:v.timeRangeStop)
  |> filter(fn: (r) =>
      r._measurement == "POWER" and
      r._field == "value" and
      r.device == "living_room"
      )
  |> aggregateWindow(every: v.windowPeriod, fn: max)
  |> map(fn: (r) => ({ _value:r._value, _time:r._time, _field:"Power (W)" }))
Run Code Online (Sandbox Code Playgroud)

功率 (W)是要使用的标签/别名。

我希望 Influx 能够提供一种更简单的方法来为所需字段添加别名。目前的方法不是很直观。

  • 如果您有多个系列,您可能希望包含查询中的标签或其他字段,如果您想做的只是重命名字段,那么您应该使用“r with”运算符来继承内容并仅重命名字段。示例: |> map(fn: (r) => ({ r with _field:"Power (W)" })) (2认同)

ffi*_*ffi 7

有点类似于塞巴斯蒂安科尔马尔的建议,但我不确定这是否正是他的意思 - 我的一位同事提出了这个:

图1

只需进行很少的更改或无需更改,这可能会实现您想要的效果。

编辑:我对这个问题的最初解释是,目标只是删除图例中括号内的文本。如果目标更根本的是改变数据的分组方式,请参阅下面的评论