工业物联网数据桥接教程:Modbus 桥接到 MQTT

news2024/12/29 10:53:43

Modbus 介绍

Modbus 是一种串行通信协议,用于连接工业自动化设备,最初由 Modicon 公司开发,诞生于 1979 年,现在已成为通用的通讯标准之一,广泛用于工业自动化场景。

Modbus 采用主从模式,支持多种传输方式,包括串行(RS-232/485)和以太网版本(TCP/IP)。其主要用于监视和控制自动化设备,例如传感器、电机和 PLC 等。它可以实现设备间的数据交换和控制命令发送,使得各个设备之间能够互相协调工作。

Modbus 协议中定义了四种类型的存储区,分别为线圈(Coils)、离散输入(Discrete Inputs)、输入寄存器(Input Registers)和保持寄存器(Holding Registers)。不同类型的存储区对应着不同的读写操作。

存储区名称数据类型访问类型PLC 地址寄存器地址
线圈读写000001-0655360-65535
离散输入只读100001-1655360-65535
输入寄存器只读300001-3655360-65535
保持寄存器读写400001-4655360-65535

四种存储区都有各自的地址范围和读写操作码,根据应用场景选择合适的存储区进行读写操作。

以 Modbus TCP 为例,其报文结构为MBAP(报文头)+PDU(帧结构)。

报文头帧结构
事物标识符协议标识符长度单元标识符功能码数据

Modbus 协议定义多种功能码实现对存储区的读写,下面列举常见功能码。

功能码功能位/字操作操作数量
01读线圈状态位操作单个或多个
02读离散输入状态位操作单个或多个
03读保持寄存器字操作单个或多个
04读输入寄存器字操作单个或多个
05写单个线圈位操作单个
06写单个保持寄存器字操作单个
15写多个线圈位操作多个
16写多个保持寄存器字操作多个

假设从机地址为 01H,读取的保持寄存器起始地址为 006BH,读取 2 个寄存器,指令如下:

从机地址功能码起始地址高位起始地址低位寄存器数量高位寄存器数量低位
0103006B0002

每个保持寄存器的长度为 2 个字节。低地址寄存器先传输,高地址寄存器后传输。每个寄存器数据高字节数据先传输,低字节数据后传输。响应如下:

从机地址功能码字节数006BH高字节006BH低字节006CH高字节006CH低字节
01030400000000

为什么将 Modbus 桥接到 MQTT

随着工业 4.0 的到来,制造业中的智能化、自动化和数据化需求越来越高。在这种背景下,Modbus 协议也面临了一些挑战。

首先,Modbus 协议在安全性方面存在较大问题。由于其通信方式较为简单,容易受到黑客攻击和数据篡改等安全问题。

其次,在实时性和带宽利用率方面,Modbus 协议与现代工业通信标准相比显得不够优秀。特别是在大规模设备联网的情况下,传统的串行通信方式已经不能满足要求。

此外,在多层次架构和云平台应用方面,Modbus 协议还存在一定的局限性。它只能进行点对点通信,并没有很好地支持分布式系统和云计算平台。

MQTT 相比于 Modbus 优势明显。MQTT 协议是一种基于发布/订阅模式的轻量级消息传输协议,其构建于 TCP/IP 协议上,由 IBM 在 1999 年发布。2014 年 10 月 29 日,MQTT 成为 OASIS 正式批准的通讯标准。目前已经广泛应用于物联网、移动互联网、智能硬件、车联网、智慧城市、远程医疗、电力、石油与能源等领域。

MQTT 主要有以下优势:

  • 轻量级:MQTT 非常轻量级,可以在带宽有限、网络质量不好的环境下使用。
  • 灵活性:MQTT 支持多种连接方式,通过订阅/发布模式实现灵活的消息传递。
  • 可靠性:MQTT 可以保证消息的可靠传输,即使网络中断也可以重新连接并恢复通信。
  • 安全性:MQTT 支持 SSL/TLS 加密和认证机制,可以保障数据安全性。

因此,在物联网领域,MQTT 更适合于分布式系统中的消息传递。可以将 Modbus 桥接 MQTT 取长补短,完成升级改造。

Modbus 桥接到 MQTT 的架构

Modbus 数据源将数据发送到 MQTT Broker,MQTT Broker 接收并转发。实现此过程需要两个组件:一是边缘端将 Modbus 协议转换为 MQTT 并发送到 MQTT Broker;二是需要一个处理 MQTT 消息的 MQTT Broker。

EMQ 旗下的 Neuron 可以将 Modbus 协议转换为 MQTT;EMQX 则可以作为 MQTT Broker 处理海量连接。

Neuron 是一款现代的工业物联网连接服务器,可以连接多种使用标准协议或者设备专有协议的工业设备,实现了工业物联网平台与各种设备的互联互通。作为一款轻量级的工业协议网关软件,Neuron 可以运行在各种有限资源的物联网边缘硬件设备上,旨在解决以数据为中心的自动化设备数据难以统一访问的问题,为智能制造提供基础支撑。

EMQX 是一款大规模可扩展的云原生分布式物联网 MQTT 消息服务器。作为全球最具扩展性的 MQTT 消息服务器,EMQX 提供了高效可靠海量物联网设备连接,能够高性能实时移动与处理消息和事件流数据,帮助用户快速构建关键业务的物联网平台与应用。

下面展示了 Neuron 从边缘端采集数据并转换为 MQTT 上传到 MQTT broker 的架构。

Modbus 桥接到 MQTT 的架构

通过 Neuron 将 Modbus 桥接到 MQTT

此章节将介绍如何使用 Neuron 采集 Modbus 设备的数据,将采集到的数据上传到 MQTT Broker(EMQX),并使用 MQTTX 查看。

EMQX 快速使用

EMQX 提供多种安装方式,用户可在 安装 中查看详细的安装方式。本实例采用容器化部署的方式,以便于最快开始体验 EMQX。

运行以下命令获取 Docker 镜像:

docker pull emqx/emqx:5.1.0

运行以下命令启动 Docker 容器

docker run -d --name emqx -p 1883:1883 -p 8081:8081 -p 8083:8083 -p 8084:8084 -p 8883:8883 -p 18083:18083 emqx/emqx:5.1.0

通过浏览器访问 http://localhost:18083/ (localhost 可替换为您的实际 IP 地址)以访问 EMQX Dashboard 管理控制台,进行设备连接与相关指标监控管理。本教程保持 docker 启动即可。

初始用户名: admin ,初始密码:public

安装 Modbus 模拟器

安装 PeakHMI Slave Simulators 软件,安装包可在 PeakHMI 官网 中下载。

安装后,运行 Modbus TCP slave EX。须保证 Neuron 与模拟器运行在同一局域网内。

点击 Windows->Register data 查看数据。

选择站点号 1。

选择站点号 1。

选择 Holding Registers。至此,成功启动模拟器,保持模拟器打开,接下来操作 Neuron。

选择 Holding Registers

Neuron 快速开始

Neuron 提供多种安装方式,用户可在 安装 中查看详细的安装方式。本实例采用容器化部署的方式,以便于最快开始体验 Neuron。

获取 Docker 镜像:

$ docker pull emqx/neuron:latest

启动 Docker 容器:

$ docker run -d --name neuron -p 7000:7000 --privileged=true --restart=always emqx/neuron:latest

打开 Web 浏览器,输入运行 Neuron 的网关地址和端口号,即可进入到管理控制台页面,默认端口号为 7000。通过浏览器访问 http://localhost:7000/ (localhost 可替换为您的实际 IP 地址)

第一步,登录

页面打开后,进入到登录界面,用户可使用初始用户名与密码登录(初始用户名:admin,初始密码:0000)。

第二步,添加南向设备

配置 菜单中选择 南向设备,进入到南向设备界面,点击 添加设备 新增设备。

  • 名称:填写设备名称,例如 modbus-tcp-1;
  • 插件:下拉框选择 Modbus TCP 插件。

第三步,设置南向设备参数

添加南向设备后自动进入设备配置界面,填写参数并提交。

  • 传输模式:选择 TCP;
  • 连接模式:选择 Client;
  • 最大重试次数:默认 0;
  • 指令重新发送间隔:默认 0;
  • 指令发送间隔:默认 20;
  • IP 地址:填写安装 PeakHMI Slave Simulators 软件的 PC 端 IP 地址;
  • 端口号:默认 502;
  • 连接超时时间:默认 3000。

第四步,在设备卡片中创建组

点击设备节点卡片任意空白处,进入组列表管理界面,点击 创建 ,弹出 创建组 的对话框。填写参数并提交:

  • 组名称:填写组名称,例如 group-1;
  • 间隔:默认 1000。

第五步,在组中添加数据点位

点击组卡片任意空白处,进入点位列表管理界面,点击 创建 ,进入添加点位页面。

在组中添加数据点位

填写点位参数并提交:

  • 名称:填写点位名称,例如,tag-1;
  • 属性:下拉选择点位属性,例如,Read,Write;
  • 类型:下拉选择数据类型,例如,INT16;
  • 地址:填写驱动地址,例如,1!40001。1 代表 Modbus 模拟器中设置的点位站点号,40001 代表点位寄存器地址;
  • 描述、乘系数、精度不填。

第六步,数据监控中查看采集数据

选择监控数据监控,进入数据监控界面,查看已创建点位读取到的数值,如下图所示。

查看采集数据

注意,请确认 Modbus 模拟器已启动。

数据监控以组为单位显示数值:

  • 南向设备:下拉框选择想要查看的南向设备,例如,选择已创建的 modbus-tcp-1;
  • 组名称:下拉框选择想要查看所选南向设备下的组,例如,选择已创建的 group-1;
  • 选择完成,页面将会展示读取到的组中所有点位的值。

第七步,为应用程序添加北向插件模块

创建北向应用, Neuron 与北向应用建立连接并将采集到的设备数据上传到 MQTT Broker(EMQX)。

配置菜单中选择北向应用,点击 添加应用 ,如下图所示。

添加应用

添加一个 MQTT 云连接模块:

  • 名称:填写应用名称,例如,MQTT;
  • Plugin:下拉框选择 MQTT 插件。

第八步,设置北向应用参数

添加北向应用后自动进入应用配置界面,填写参数并提交。

设置 MQTT 连接:

  • 客户端 ID:注意此 ID 要相互独立,重复 ID 会导致客户端被踢除。例如设置为,MQTT1999;
  • QoS 等级:默认为 0;
  • 上报数据格式:默认为 Values-format;
  • 写请求主题:默认为 /neuron/MQTT/write/req;
  • 写响应主题:默认为 /neuron/MQTT/write/resp;
  • 离线缓存:默认关闭;
  • 服务器地址:填写创建的 emqx broker 地址,地址为部署 emqx 的地址 localhost,即您实际的 IP 地址。
  • 服务器端口:默认 1883;
  • 用户名、密码:不填;
  • SSL:默认关闭。

第九步,订阅南向点位组

点击刚创建的 MQTT 应用节点卡片任意空白处,进入订阅组界面,点击 添加订阅

订阅南向设备的数据组:

  • 南向设备:下拉框选择已创建的南向设备,例如,modbus-tcp-1;
  • 组:下拉框选择所要订阅的组,例如,group-1;
  • 主题:MQTT 主题,本例中默认为 /neuron/MQTT/group-1。接下来在 MQTTX 中订阅此主题并接收消息。

第十步,在 MQTT 客户端查看数据

订阅完成后,除了 neuron 自己的数据监控界面,用户可以使用 MQTT 客户端 - MQTTX 连接到 EMQX 来查看上报的数据。

启动 MQTTX 后在主页面点击 + New Connection,填写配置参数后,点击右上角连接。

  • 名称:对消息起名便于查看,例如起名为 modbus-tcp;

  • Client ID:使用默认值即可,保证 ID 独立;

  • 服务器地址:下拉框选择 ws://emqx@localhost,(localhost 可替换为您的实际 IP 地址);

  • 端口:8083。

    其他参数选填,完成后点击右上角连接。成功连接后订阅主题。

  • 点击 添加订阅,Topic 与第九步中的主题一致。例如,填写 /neuron/MQTT/group-1

订阅成功后可以看到 MQTTX 持续接收到 Neuron 采集并上报过来的数据。如下图所示。

MQTTX 持续接收到 Neuron 采集并上报过来的数据

工业物联网应用场景

石油生产数据采集

随着石油生产数字化建设规模的扩大,自动化设备的数量也在增加,导致了数据采集和管理的复杂性。

设备侧通过边缘工业协议网关软件 Neuron 对接各类工业设备,可以将石油生产环境中的 DTU、RTU 以及各类型 PLC 的数据进行统一采集。同时在设备上报过程中实现对采集点、采集频率、上报频率、上报格式的统一规划,方便上层业务系统存储与数据消费。

石油生产数据采集

结合 Neuron 和 EMQX、eKuiper、EMQX-ECP 等其他 EMQ 产品的整体解决方案可以为石油行业带来以下好处:

  • 轻前端、重后端的系统架构,降低现场设备与系统运维成本。
  • 基于物联网协议作为数据采集与传输的主要方式,实现了生产数据低时延实时上报,提高业务响应能力。
  • 解决海量异构设备与系统的实时数据统一汇聚,实现了各类型生产与监控设备数据统一汇聚存储,使数据资产有效整合。
  • 通过统一接入平台以及平台提供的丰富数据接口,实现数据采集与数据消费系统的解偶,使应用开发更加便捷高效。

赋能工业网络化、数字化和智能化

统一的一站式工业物联网数据平台在工业 4.0 的背景下变得至关重要。

Neuron 可以支持 Modbus、OPC-UA、IEC61850、IEC104 等完整工业协议,实现各类异构工业设备数据的高效接入。轻量级边缘流处理引擎 eKuiper 在边缘端进行采集、过滤、补全、时间窗口计算等,为边缘 AI 推理服务提供高质量数据源。

通过在云端实现实时数据连接、移动、存储、处理和分析,这为大数据分析和人工智能应用奠定了坚实的数据基础,使企业能够快速开发上层应用。

一站式工业物联网数据平台

结语

使用 Modbus 协议可以实现设备之间的通信和数据交换,而 MQTT 则提供了一种高效、灵活且安全的消息传输机制。通过将 Modbus RTU 或 TCP 转换为 MQTT 消息,可以轻松地将设备数据发送到云端,并在需要时进行远程控制和监控。这种方式可以帮助工业企业更好地管理其设备和生产过程,并提高生产效率和质量。

版权声明: 本文为 EMQ 原创,转载请注明出处。

原文链接:https://www.emqx.com/zh/blog/bridging-modbus-data-to-mqtt-for-iiot

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/873473.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

jacoco功能测试-代码覆盖率

1、下载 jacoco 官网地址:EclEmma - JaCoCo Java Code Coverage Library 2、拷贝 jar 包 下载好后,找到这两个文件,然后找到被测项目 3、启动 jacocoagent,监控被测项目 java -javaagent:jacocoagent.jarincludes*,outputtcp…

BGP总结

前言 我们从动态路由协议的应用范围可以分为IGP(内部网关协议)和EGP(外部网关协议)。 IGP协议追求: 无环(选路佳)收敛快占用资源少 EGP协议的追求 可控性强(管理员可以方便进行…

Rx.NET in Action 第二章学习笔记

Part 1 初入反应式扩展 2 Hello, Rx 本章节涵盖的内容: 不使用Rx的工作方式向项目中添加Rx创建你的第一个Rx应用程序 Rx 的目标是协调和统筹来自社交网络、传感器、用户界面事件等不同来源的基于事件的异步计算。例如,建筑物周围的监控摄像头和移动传感器会在有人靠…

激活函数总结(三):激活函数补充

激活函数总结(三):激活函数补充 1 引言2 激活函数2.1 Softmax激活函数2.2 Softplus激活函数2.3 Mish激活函数2.4 Maxout激活函数 3. 总结 1 引言 在前面的文章中已经介绍了过去大家较为常见的激活函数 (Sigmoid、Tanh、ReLU、Leaky ReLU、PR…

42 | 航空公司客户价值分析

民航的竞争除了三大航空公司之间的竞争之外,还将加入新崛起的各类小型航空公司、民营航空公司,甚至国外航空巨头。航空产品生产过剩,产品同质化特征愈加明显,于是航空公司从价格、服务间的竞争逐渐转向对客户的竞争。 目前航空公司已积累了大量的会员档案信息和其乘坐航班…

vscode debug python 带参数

两种方法 第一种: 1,侧边栏选择运行和调试 2,请先创建一个launch.json文件 3,并选择配置文件为python文件 此时你的工作目录下会多一个目录.vscode和该目录下一个launch.json文件,该文件则配置了你的debug配置。在…

JZ40最小的K个数

题目地址:最小的K个数_牛客题霸_牛客网 题目回顾: 解题思路: 注意本题不需要去重。 最简单的方法:排序后数组顺序是由小到大的,也就是说此时数组前k个数就是我们要求的结果。 整体代码: public ArrayLi…

WPF 界面结构化处理

文章目录 概要一、xaml界面结构化处理二、逻辑树与视觉树 概要 WPF 框架是开源的,但是不能跨平台,可以使用MAUI,这个框架可以跨平台,WPF源码可以在github上下载,下载地址:https://gitbub.com/dotnet/wpf。…

【推荐系统】wss课程-排序

排序01-多目标模型 这节课的内容是推荐系统排序的多目标模型。这节课的内容分两部分。 - 第一部分是模型结构。模型把用户特征、物品特征、统计特征、场景特征作为输入,输出对多个指标的预估。 - 第二部分内容是降采样和校准。在实际的推荐系统中,正负…

Mybatis三剑客(一)在springboot中自动生成Mybatis【generator】

1、pom.xml中新增plugin <plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.7</version><configuration><overwrite>true</overwrite><…

Dynamic Web TWAIN Crack

Dynamic Web TWAIN Crack 文件编辑 提供 GUI 和非 GUI 图像编辑器 内置基本图像编辑界面&#xff0c;如旋转、裁剪、镜像、翻转、擦除和更改图像大小 支持向图像添加彩色矩形 支持文字注释 提供图像交换功能 支持清除图像的指定区域并用颜色填充清除的区域 内置变焦 提供多图像…

Simulink建模:位运算

本文研究Simulink中常用的按位运算的建模方法。 文章目录 1 引入2 位运算模块2.1 移位模块2.1 按位逻辑运算 3 代码生成4 位运算的应用4.1DBC矩阵解析4.2 bool信号打包 5 总结 1 引入 在计算机的基础课中&#xff0c;学过把一个十进制数转换成二进制数。例如&#xff0c;十进…

每天一道leetcode:712. 两个字符串的最小ASCII删除和(动态规划中等)

今日份题目&#xff1a; 给定两个字符串s1 和 s2&#xff0c;返回 使两个字符串相等所需删除字符的 ASCII 值的最小和 。 示例1 输入: s1 "sea", s2 "eat" 输出: 231 解释: 在 "sea" 中删除 "s" 并将 "s" 的值(115)加入…

【【萌新的STM32学习-8】】

萌新的STM32学习-8 STM32CubeMX 是由 ST 公司开发的图形化代码自动生成工具&#xff0c;能够快速生成初始化代码&#xff0c; 如配置 GPIO&#xff0c;时钟树&#xff0c;中间件等&#xff0c;使用户专注于业务代码的开发。现在 ST 主推 HAL 库代码&#xff0c; 经典的标准外设…

82. 删除排序链表中的重复元素 II

题目链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 解题思路&#xff1a;设置一个新的哑元节点result&#xff0c;作为头节点&#xff0c;将head中不重复地节点依次链接到哑元节点后面&#xff0c;最后返回result.next 初始值&…

Dynamic CRM开发 - 实体介绍

实体简介 在CRM中,实体(Entity)是数据的基本载体,也是构建业务逻辑网络的基础节点。 实体可以理解为数据库中的一张表(实体中的字段对应数据库表的字段),比如创建一个实体存储客户信息,创建一个实体存储产品信息,产品实体里可以创建一个查找类型的字段(类似表的外键)…

尚医通(医院预约挂号系统)笔记

文章目录 一. 登录系统1. 手机登录1.1 业务流程1.2 代码1.3 JWT 2. 微信登陆2.1 业务流程2.2 代码2.3 OAthu2 3. 用户认证与网关整合 二. 预约挂号1. 业务流程及模块设计 一. 登录系统 1. 手机登录 1.1 业务流程 传入手机号和验证码校验手机号和验证码是否为空校验手机验证码…

阿里云新用户和老用户是如何界定的?产品首购资格是什么?

阿里云新用户条件是什么&#xff1f;针对新用户优惠有哪些&#xff1f;阿里云新用户怎么算&#xff1f;新用户购买云服务器、域名等更优惠&#xff0c;如何获取新用户特价资格&#xff1f;阿里云新用户是指从未购买阿里云产品的用户&#xff08;域名除外&#xff09;&#xff0…

《TCP IP网络编程》第十六章

第 16 章 关于 I/O 流分离的其他内容 16.1 分离 I/O 流 「分离 I/O 流」是一种常用表达。有 I/O 工具可区分二者&#xff0c;无论采用哪种方法&#xff0c;都可以认为是分离了 I/O 流。 2次 I/O 流分离&#xff1a; 第一种是第 10 章的「TCP I/O 过程」分离。通 shutdown(soc…

英语——时态

动词随着所表现出的时间而改变的形态&#xff0c;称为时态&#xff0c;包含以下12种 现在过去将来一般一般现在时一般过去时一般将来时进行现在进行时过去进行式将来进行时完成现在完成时过去完成时将来完成时完成进行现在完成进行时过去完成进行时将来完成进行时 1 现在时 …