Thingsboard使用gateway网关

  • 作者: 凯哥Java(公众号:凯哥Java)
  • thingsboard
  • 时间:2023-05-04 18:21
  • 4084人已阅读
简介 简介:本次是想测试一下thingsboard网关的使用,实现通过网关+mqtt+thingsboard+emqx实现间接设备创建和数据传输前期准备:thingsboard平台thingsboard网关emqx平台MQTTX工具详细过程:1:thingsboard平台搭建关于thingsboard平台搭建这里就不多介绍了,主要是编译难,这个之前可以看我发布的文章,所以直接跳过。2:创建网关设备打开t

🔔🔔🔔好消息!好消息!🔔🔔🔔

有需要的朋友👉:联系凯哥 微信号 kaigejava2022

简介:

本次是想测试一下thingsboard网关的使用,实现通过网关+mqtt+thingsboard+emqx

实现间接设备创建和数据传输


前期准备:

thingsboard平台

thingsboard网关

emqx平台

MQTTX工具


详细过程:

1:thingsboard平台搭建

关于thingsboard平台搭建这里就不多介绍了,主要是编译难,这个之前可以看我发布的文章,所以直接跳过。


2:创建网关设备

打开thingsboard平台,点击设备管理界面,点击新建网关设备。

5a53a9e28407e838171f11bf35ef8a15.png

3:thingsboard网关

首先去github搜索thingboard下载对应网关代码,
地址:https://github.com/thingsboard/thingsboard-gateway

cd87af73e6fee966b65b5dac3a796efe.png

下载下来后通过代码我们可以发现是使用python写的,可以用pycharm或idea打开,这里我们使用idea打开。

然后第一步肯定是编译了,对应python项目编译,可以直接点击运行,看报什么错误,少什么模块直接引入对应模块,这里附上我最后编译成功后引入的模块。

3b78ee69229bde959603cfb397a24fc7.png

引入对应模块包时注意,模块名对应包名可能有些会存在差异,这个和python2和python3的区别有关系。

对应编译过程中,对于有些模块引入失败但是其对应功能不重要时,可以先注释掉,后面有时间再回来看。

例如:楼主有个模块mmh3引入失败,然而发现其非必须时先注释掉,这个mmh3主要是一些加密算法相关的,后面有时间可以去研究一下。

0d362026e92c3d5b6bc7ca2bd1cc1f9d.png

938e86477c5abd5558fbe9749c0e70bf.png

对应thingsboard-way项目启动时要注意两个配置地方修改。
1:tb_gateway.yaml文件
2:mqtt.json文件修改,(因为此次我们测试是mqtt,如果测试其他时对应修改其他配置文件即可)

93f724a374156aec17f80e84259c6643.png

首先我们看到tb_gateway.yaml

3f8bb7d3bcf764c060ee3fda1ebfa0db.png

这里主要注意改一下host和port对应thingsboard平台地址和端口
accessToken对应刚才我们创建的网关设备访问令牌。
然后我们看到mqtt.json文件内容

2a3aed12cd1951553f56c3af771fd22b.png

这里的host和port对应我们搭建的emqx平台的地址和端口,后面会讲。
对应这个项目编译一般都会一系列问题,有点耐心慢慢解决就好了,这里我们改完相应配置后直接启动。在emqx界面上也能看到我们对应的thingsboard-gateway客户端e78394a4d27b965f4377bb55d5a5f453.png

4:emqx搭建

emqx我们可以知道,是一个大规模分布式物联网 MQTT 消息服务器,可以
高效可靠连接海量物联网设备,实时处理分发消息与事件流数据,助力构建关键业务的物联网平台与应用。
这里我们采用docker拉取对应镜像构建。
1拉取镜像

docker pull emqx/emqx:latest

2构建启动容器,指定端口

docker run -d --name emqx -p 1883:1883 -p 8081:8081 -p 8083:8083 -p 8883:8883 -p 8084:8084 -p 18083:18083 0ef9bc19d70e

端口说明
1883:MQTT 协议端口
8883:MQTT/SSL 端口
8083:MQTT/WebSocket 端口
8080:HTTP API 端口
18083:Dashboard 管理控制台端口
0ef9bc19d70e:刚才我们拉取镜像对应的image_id


3容器启动成功后,打开界面控制台看是否搭建成功。(记得开放对应端口,例如楼主是在阿里云服务器上搭建的找到对应规则开放对应端口,不然是看不到界面的)
访问地址:http://服务器公网ip:18083
登录默认用户名:admin,密码:public

d5a3335dc312257863b2f67146cff8fe.png

5:使用MQTTX连接我们的emqx服务器发送设备数据到thingsboard平台。

f325fa5b4d4f88ade13cdb1db087ec74.png

连接成功后填写相应主题和消息后点击发送。

d03bf5d897078a813ef7173172c8e1c4.png

发送成功后我们打开thingsboard设备界面,记得刷新一下。

e360da94f19423e83a2c0c474a7a0cbb.png

bd421cd1feee7e1226a5e2bb504a73ca.png

可以看到thingsboard平台上自动为我们创建了设备,且遥测数据也发送成功了,至此我们间接地通过网关帮我们创建了设备且成功上传了数据,大功告成。这个流程通了之后,我们就可以根据我们的业务需求来进行改进。

6:对应mqtt.json文件的解释

d7631863c526ebc289c057325cebd488.png

这里的mapping是一个数组列表,里面包含之前定义好的模板。

我们先看到第一个。

topicFilter:对应发送消息的主题

deviceNameJsonExpression:对应在thingsboard平台自动创建的设备名字

deviceTypeJsonExpression:对应设备配置名称

63efeb655a0309eb639b4b108c4ab2ad.pnged08a01d9b182317f5ed688f5b56f4aa.png


attributes对应设备的客户端属性,可以自己定义,根据样例修改。

744853185cfed04639cdfc54cb1fba68.png

timeseries对应遥测数据数组列表,这个遥测数据对应key和value可以根据自己的需求自己定义修改。

接下来我们看到第二个主题

/sensor/+/data

+号代码设备名字,自己填写,后面的属性配置和之前我解释的一样,就不细说了。

后面还有几个规则,这里楼主还没研究,这个后面有时间再细看一下,就先到这里了,感兴趣的可以自己去研究一下。


总结:

本次调试了thingsboard网关的功能,一顿操作下来还是花费了不少时间了,主要都是花在项目编译上,解决项目运行出现的问题,总的来说还是收获不少。这次通过网关间接地在thingsboard平台创建设备和发送遥测数据,采用的还是mqtt协议,后面会再测试一下其他协议的接入过程,感兴趣的小伙伴可以一起交流呀。



TopTop