Docker容器实现边缘采集

描述

Node-RED环境搭建

Node-RED是构建物联网(IoT,Internet of Things)应用程序的一个强大工具,其重点是简化代码块的“连接”以执行任务。它使用可视化编程方法,允许开发人员将预定义的代码块(称为“节点”,Node)连接起来执行任务。连接的节点,通常是输入节点、处理节点和输出节点的组合,当它们连接在一起时,构成一个“流”(Flows)。

Docker

 Node-RED网关开发环境安装流程

 

docker环境如何部署,网上已经有很多教程,这里不再说明,推荐参考官方安装说明。

 


 

项目镜像安装

docker安装项目文件非常的简单,只需要两条指令即可实现Node-RED开发环境部署,其中第一条通过“docker pull 存储库名称”,就可以项目镜像,也可以通过“docker --help”查询指令说明。

Docker

docker --help指令(部分)


 

从Node-RED 1.0开始,Docker Hub上的存储库已重命名为“nodered/node-red”,使用“docker pull nodered/node-red”拉取项目镜像。

要以最简单的形式在 Docker 中运行,只需运行:

docker run -it -p 1880:1880 -v node_red_data:/data --name mynodered nodered/node-red

让我们解读下指令:

docker run:运行容器;

-it:打印安装会话,可以省略;

-p:配置本地端口和外部映射端口;

-v node_red_data:/data:挂载一个名为“node_red_data”的docker到容器/数据目录;

--name mynodered:命名为“mynodered”;

nodered/node-red:镜像地址;

只使用“Docker run”不先拉取项目镜像也是可以的,该指令会查询本地镜像如果没有就会自动从Docker Hub存储库下载项目镜像;

其他的自定义安装建议仔细阅读Node-RED官方文档后进行,笔者这里只是介绍这个工具的一种用法,不使用自定义安装功能。

 

安装插件

通过Node-RED默认安装环境是无法实现RTU设备的边缘采集,还需要通过安装不同的功能插件才能实现,安装Modbus功能插件(node-red-contrib-modbus)实现Modbus RTU/Modbus TCP协议转换和边缘采集,安装数据库插件(node-red-node-mysql)实现边缘采集数据的存储,除了安装插件还需要少量的“javascript”脚本转换格式和数据上报等。

 

好在安装插件的过程可以通过可视化网页界面实现,无需理解复杂的安装指令,这也是Node-RED的优点之一,在地址栏中输入部署Node-RED环境的IP地址和端口,这里为192.168.88.5:1880。

Docker

打开右上角的菜单,选择节点管理,点击“安装”,搜索框中输入Modbus功能插件(node-red-contrib-modbus)和数据库插件(node-red-node-mysql)。

Docker

成功安装节点后在工具栏新增以下节点:
 

Docker

“node-red-contrib-modbus”节点作者,制作了不同用法的示例,可以通过导入功能,测试理解不同节点的功能,强烈建议多去理解这些实例,方便后续使用。

Docker

 

网关实现

Docker

添加“Modbus read”节点周期查询Modbus设备状态,第一需要配置Modbus设备的地址,笔者这里使用“Modbus Slave”软件模拟,地址为192.168.88.100:8890:

Docker

图左通过双击打开“Modbus read”配置界面,图右新增Modbus设备连接地址,图中配置寄存器参数,这里以地址0x0000的保持寄存器为例,配置“Poll Rate”查询周期。
 

使用“function”节点提取“Modbus read”节点周期查询的数据,双击打开函数节点,编辑以下脚本:

msg.payload=msg.payload.data;

msg.payload=msg.payload.slice(0,1);

return msg;

使用“template”将“function”节点处理的结果进行打包,这里将数据打包为JSON数据:

Docker

最后通过TCP连接将数据传输到指定服务器:
 

Docker

“6”为“DEBUG”节点用于调试,通过上述配置就可以将Modbus TCP指令采集到的数据转换为JSON数据并将数据上报到指定服务器:

Docker

也可以通过Node-RED提供的MQTT连接节点将数据传输到服务器,同时也可以通过“mysql”节点将将采集数据通过sql语句传输到数据库。
 

Docker

采集上报数据库与MQTT服务器流程举例


 

至此,一个简单的边缘采集网关搭建完成。

 

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分