使用EMQX将数据写入IotDB

一、启动一个IotDB容器

bash 复制代码
sudo docker run --rm -p 6667:6667 -p 2883:2883 -e enable_rest_service=true -e enable_mqtt_service=true -e mqtt_port=2883 --name iotdb apache/iotdb:1.3.2-standalone 

重要参数解析:

1. 容器生命周期管理

--rm

  • 容器停止后自动删除,避免积累未使用的容器

2. 网络端口映射

bash 复制代码
-p 6667:6667 -p 2883:2883
  • -p 6667:6667: 将容器内的 6667 端口映射到主机的 6667 端口

    • 6667 是 IoTDB 的默认 RPC 端口
  • -p 2883:2883: 将容器内的 2883 端口映射到主机的 2883 端口

    • 2883 是 MQTT 服务端口

3. 环境变量配置

bash 复制代码
-e enable_rest_service=true
-e enable_mqtt_service=true  
-e mqtt_port=2883
  • 启用 REST API 服务

  • 启用 MQTT 协议支持

  • 设置 MQTT 服务端口为 2883

二、设置存储组

bash 复制代码
# 进入容器内部
docker exec -it iotdb bash start-cli.sh -h 127.0.0.1 -p 6667 -u root -pw root

# 设置存储组
set storage group to root.imooc;

三、在Emqx创建连接器,设置规则和添加动作

1、创建连接

连接器上填写的信息MQTT服务地址,为上面启动的Iotdb容器的服务器地址和端口,用户名和密码默认为root。填写好点击下方的测试连接,如果提示连接成功,则进入下一步。

2、设置规则

重点说下里面的SQL

sql 复制代码
SELECT
  clientid,
  now_timestamp('millisecond') as now_ts_ms,
  payload.charging as charging
FROM
  "charge/stat"

FROM中的charge/stat为主题,payload.charging为发送的消息

编写完SQL可以启用调试,以验证是否正确

主题必须与SQL中from后面的主题保持一致,Payload也必须SQL中的payload点后面的值保持一致,编写完点击运行测试,如果无误,可以在输出结果中看到正常输出的结果。

3、添加动作

这里主要是选择连接器和主题,然后填写消息模板,消息模板要写对,否则消息无法保存到IotDB中。消息模板的示例:

sql 复制代码
{
  "device":"root.imooc.${clientid}",
  "timestamp":${now_ts_ms},
  "measurements":[
    "charging"
    ],
  "values":[
    ${charging}
    ]
}

device中root.imooc为IotDB中存储组的名称,measurements为payload的值,values需要提供数组的形式数据,为payload的值。

四、在mqttx上发送消息

五、验证消息

在emqx上查看消息是否命中

使用IotDB查询数据是否写入

从中可以看到数据已经写入到IotDB。

相关推荐
wei_shuo3 天前
Apache IoTDB 架构特性与 Prometheus+Grafana 监控体系部署实践
架构·apache·iotdb
檀越剑指大厂21 天前
Apache IoTDB:为工业物联网数据打造的专属“智慧中枢
物联网·apache·iotdb
熊文豪22 天前
时序数据库选型指南:如何为企业选择合适的时序数据库解决方案
数据库·时序数据库·iotdb
Apache IoTDB23 天前
训练“系统级思维”,听 IoTDB Committer 说说从设计到应用的成长
iotdb
鲲志说24 天前
数据洪流时代,如何挑选一款面向未来的时序数据库?IoTDB 的答案
大数据·数据库·apache·时序数据库·iotdb
时序数据说1 个月前
时序数据库 IoTDB:支撑万亿级物联网设备的基石
大数据·数据库·物联网·时序数据库·iotdb
颜颜yan_1 个月前
时序数据库选型指南:Apache IoTDB引领数字化转型新时代
apache·时序数据库·iotdb
一个天蝎座 白勺 程序猿1 个月前
Apache IoTDB(6):深入解析数据库管理操作——增删改查与异构数据库实战指南
数据库·apache·时序数据库·数据库管理·iotdb
是Dream呀1 个月前
时序数据库选型指南:Apache IoTDB企业级解决方案深度解析
apache·时序数据库·iotdb