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

如何解决Grafana - InfluxDB 2 - 标签/别名数据

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

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

enter image description here

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

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)

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

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

例如,如果我这样做:

from(bucket: "main")
  |> range(start: v.timeRangeStart,fn: sum)
  |> map(fn: (r) => ({ POWER: r._value }))

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

我也试过使用

from(bucket: "main")
  |> range(start: v.timeRangeStart,fn: sum)
  |> yield(name: "POWER")

那也行不通。我尝试了很多其他的东西都没有成功。

我该如何解决这个问题?

解决方法

经过数小时的反复试验,我终于找到了一个可行的解决方案。我想其他用户可能会遇到同样的问题,因此我不会删除该问题,而是提供我的解决方案。

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

解决方案如下:

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)" }))

Power (W) 是将要使用的标签/别名。

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?