Thingsboard使用gateway网关

简介:

本次是想测试一下thingsboard网关的使用,实现通过网关+mqtt+thingsboard+emqx
实现间接设备创建和数据传输

前期准备:

thingsboard平台
thingsboard网关
emqx平台
MQTTX工具

详细过程:

1:thingsboard平台搭建

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

2:创建网关设备

打开thingsboard平台,点击设备管理界面,点击新建网关设备。
在这里插入图片描述

3:thingsboard网关

首先去github搜索thingboard下载对应网关代码,
地址:https://github.com/thingsboard/thingsboard-gateway
在这里插入图片描述
下载下来后通过代码我们可以发现是使用python写的,可以用pycharm或idea打开,这里我们使用idea打开。

然后第一步肯定是编译了,对应python项目编译,可以直接点击运行,看报什么错误,少什么模块直接引入对应模块,这里附上我最后编译成功后引入的模块。
在这里插入图片描述
引入对应模块包时注意,模块名对应包名可能有些会存在差异,这个和python2和python3的区别有关系。
对应编译过程中,对于有些模块引入失败但是其对应功能不重要时,可以先注释掉,后面有时间再回来看。
例如:楼主有个模块mmh3引入失败,然而发现其非必须时先注释掉,这个mmh3主要是一些加密算法相关的,后面有时间可以去研究一下。
在这里插入图片描述
在这里插入图片描述

对应thingsboard-way项目启动时要注意两个配置地方修改。
1:tb_gateway.yaml文件
2:mqtt.json文件修改,(因为此次我们测试是mqtt,如果测试其他时对应修改其他配置文件即可)
在这里插入图片描述
首先我们看到tb_gateway.yaml
在这里插入图片描述
这里主要注意改一下host和port对应thingsboard平台地址和端口
accessToken对应刚才我们创建的网关设备访问令牌。
然后我们看到mqtt.json文件内容
在这里插入图片描述
这里的host和port对应我们搭建的emqx平台的地址和端口,后面会讲。
对应这个项目编译一般都会一系列问题,有点耐心慢慢解决就好了,这里我们改完相应配置后直接启动。在emqx界面上也能看到我们对应的thingsboard-gateway客户端

在这里插入图片描述

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
在这里插入图片描述

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

在这里插入图片描述
连接成功后填写相应主题和消息后点击发送。
在这里插入图片描述
发送成功后我们打开thingsboard设备界面,记得刷新一下。
在这里插入图片描述
在这里插入图片描述
可以看到thingsboard平台上自动为我们创建了设备,且遥测数据也发送成功了,至此我们间接地通过网关帮我们创建了设备且成功上传了数据,大功告成。这个流程通了之后,我们就可以根据我们的业务需求来进行改进。

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

在这里插入图片描述
这里的mapping是一个数组列表,里面包含之前定义好的模板。
我们先看到第一个。
topicFilter:对应发送消息的主题
deviceNameJsonExpression:对应在thingsboard平台自动创建的设备名字
deviceTypeJsonExpression:对应设备配置名称
在这里插入图片描述
在这里插入图片描述
attributes对应设备的客户端属性,可以自己定义,根据样例修改。
在这里插入图片描述
timeseries对应遥测数据数组列表,这个遥测数据对应key和value可以根据自己的需求自己定义修改。
接下来我们看到第二个主题
/sensor/+/data
+号代码设备名字,自己填写,后面的属性配置和之前我解释的一样,就不细说了。
后面还有几个规则,这里楼主还没研究,这个后面有时间再细看一下,就先到这里了,感兴趣的可以自己去研究一下。

总结:

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

你可能感兴趣的:(ThingsBoard,gateway,ThingsBoard)