创建 InfluxDB 规则

  1. 搭建 InfluxDB 数据库环境,以 MacOS X 为例:

    1. $ docker pull influxdb
    2. $ git clone -b v1.0.0 https://github.com/palkan/influx_udp.git
    3. $ cd influx_udp
    4. $ docker run --name=influxdb --rm -d -p 8086:8086 -p 8089:8089/udp -v ${PWD}/files/influxdb.conf:/etc/influxdb/influxdb.conf:ro -e INFLUXDB_DB=db influxdb:latest
  2. 创建规则:

打开 emqx dashboard 创建 InfluxDB 规则 - 图1 (opens new window) ,选择左侧的 “规则” 选项卡。

选择触发事件 “消息发布”,然后填写规则 SQL:

3.4.0 以及更老版本:

  1. SELECT
  2. payload.host as host,
  3. payload.location as location,
  4. payload.internal as internal,
  5. payload.external as external
  6. FROM
  7. "message.publish"

3.4.1 以及以后版本:

  1. SELECT
  2. json_decode(payload) as p,
  3. p.host as host,
  4. p.location as location,
  5. p.internal as internal,
  6. p.external as external
  7. FROM
  8. "message.publish"

image

  1. 关联动作:

在 “响应动作” 界面选择 “添加”,然后在 “动作” 下拉框里选择 “保存数据到 InfluxDB”。

image

  1. 填写动作参数:

“保存数据到 InfluxDB” 动作需要六个参数:

1). Measurement。指定写入到 InfluxDB 的 data point 的 measurement。

2). Field Keys。指定写入到 InfluxDB 的 data point 的 fields 的值从哪里获取。

3). Tags Keys。指定写入到 InfluxDB 的 data point 的 tags 的值从哪里获取。

4). Timestamp Key。指定写入到 InfluxDB 的 data point 的 timestamp 的值从哪里获取。

5). 设置时间戳。未指定 Timestamp Key 时是否自动生成。

6). 关联资源。现在资源下拉框为空,可以点击右上角的 “新建资源” 来创建一个 InfluxDB 资源:

image

选择 “InfluxDB 资源”:

image

  1. 填写资源配置:

本示例中所有配置保持默认值即可,点击 “测试连接” 按钮,确保连接测试成功。

最后点击 “新建” 按钮。

image

  1. 返回响应动作界面,点击 “确认”。
  2. 返回规则创建界面,点击 “新建”。

image

  1. 规则已经创建完成,现在发一条消息:

Topic: “t/1”

QoS: 0

Retained: false

Payload: “{“host”:”serverA”,”location”:”roomA”,”internal”:25,”external”:37}”

然后检查 InfluxDB,新的 data point 是否添加成功:

  1. $ docker exec -it influxdb influx
  2. > use db
  3. Using database db
  4. > select * from "temperature"
  5. name: temperature
  6. time external host internal location
  7. ---- -------- ---- -------- --------
  8. 1561535778444457348 35 serverA 25 roomA

在规则列表里,可以看到刚才创建的规则的命中次数已经增加了 1:

image