Modbus协议简介

Modbus协议简介

由于最近要参加一个通信相关的项目,涉及到Modbus协议,因此在这里做以下整理和总结。

Modbus是一种串行通信协议,是Modicon公司(现为施耐德电气公司的一个品牌)于1979年为使用可编程逻辑控制器(PLC)通信而发表的。Modbus已经成为工业领域通信协议事实上的业界标准,并且现在是工业电子设备之间常用的连接方式。

【协议版本】

Modbus协议当前存在用于串口、以太网以及其他支持互联网网络的版本。

大多数Modbus设备通信通过串口 EIA-485 物理层进行,也就是我们经常说到的RS485。

对于串行连接,存在两个变种,它们在数值数据表示和协议细节上略有不同。

          串行连接               数值数据表示                        协议细节
Modbus RTU紧凑的,采用二进制表示数据的方式TU格式后续的命令/数据带有循环冗余校验的校验和
Modbus ASCII人类可读的,冗长的表示方式ASCII格式采用纵向冗余校验的校验和

<注> 被配置为RTU变种的节点不会和设置为ASCII变种的节点通信,反之亦然。

对于通过TCP/IP(例如以太网)的连接,存在多个Modbus/TCP变种,这种方式不需要校验和计算。

Modbus有一个扩展版本Modbus Plus(Modbus+或者MB+),不过此协议是Modicon专有的,和Modbus不同。它需要一个专门的协处理器来处理类似HDLC的高速令牌旋转。它使用1Mbit/s的双绞线,并且每个节点都有转换隔离设备,是一种采用转换/边缘触发而不是电压/水平触发的设备。连接Modbus Plus到计算机需要特别的接口,通常是支持ISA(SA85),PCI或者PCMCIA总线的板卡。

【通信和设备】

Modbus协议是一个master/slave架构的协议。有一个节点是master节点,其他使用Modbus协议参与通信的节点是slave节点。每一个slave设备都有一个唯一的地址。在串行和MB+网络中,只有被指定为主节点的节点可以启动一个命令(在以太网上,任何一个设备都能发送一个Modbus命令,但是通常也只有一个主节点设备引导指令)。

一个ModBus命令包含了打算执行的设备的Modbus地址。所有设备都会收到命令,但只有指定位置的设备会执行及回应指令(地址0例外,指定地址0的指令是广播指令,所有收到指令的设备都会运行,不过不回应指令)。所有的Modbus命令包含了检查码,以确定到达的命令没有被破坏。基本的ModBus命令能指令一个RTU改变它的寄存器的某个值,控制或者读取一个I/O端口,以及指挥设备回送一个或者多个其寄存器中的数据。

Modbus之所以被如此广泛的使用主要原因有:

(1)标准、开放,用户可以免费、放心地使用Modbus协议,不需要交纳许可证费,也不会侵犯知识产权。目前,支持Modbus的厂家超过400家,支持Modbus的产品超过600种。
(2)Modbus可以支持多种电气接口,如RS-232、RS-485等,还可以在各种介质上传送,如双绞线、光纤、无线等。
(3)Modbus的帧格式简单、紧凑,通俗易懂。用户使用容易,厂商开发简单。

Modbus允许多个 (大约240个) 设备连接在同一个网络上进行通信,比如现场的温度、压力、载荷一类的传感器可以非常方便的通过Modbus将数据传输到工业控制计算机上,实现对现场各个参数的监控。

【工作原理】

在串行链路的主从通信中,Modbus主设备可以连接一个或N(最大为247)个从设备,主从设备之间的通信包括单播模式和广播模式。

在广播模式中,Modbus主设备可同时向多个从设备发送请求(设备地址0用于广播模式),从设备对广播请求不进行响应。

在单播模式中,主设备发送请求至某个特定的从设备(每个Modbus从设备具有唯一地址),请求的消息帧中会包含功能代码和数据,比如功能代码“01”用来读取离散量线圈的状态。从设备接到请求后,进行应答并把消息反馈主设备。

下图是典型的主从设备的请求-应答机制:

在主从设备的通信中,可以使用ASCII模式或者RTU模式。

在ASCII(American Standard Code for Information Interchange)传输模式下,消息帧以英文冒号(“:”)开始,以回车和换号(CRLF)符号结束,允许的传输的字符集为十六进制的0~9和A~F;网络中的从设备监视传输通路上是否有英文冒号(“:”),如果有的话,就对消息帧进行解码,查看消息中的地址是否与自己的地址相同,如果相同的话,就接收其中的数据;如果不同的话,则不予理会。

在ASCII模式下,每个8位的字节被拆分成两个ASCII字符进行发送,比如十六进制数0xAF ,会被分解成ASCII字符“A”和“F”进行发送,发送的字符量比RTU增加一倍。ASCII模式的好处是允许两个字符之间间隔的时间长达1s而不引发通信故障,该模式采用纵向冗余校验(Longitudinal Redundancy Check ,LRC) 的方法来检验错误。下面是对ASCII模式的总结:

                                      Modbus协议ASCII模式传输
   项目                                           描述
字符集16进制ASCII可打印字符0~9及A~F
每个16进制字符被拆分成2个字节发送
每个字节1个起始位
7个数据位,LSB发送模式
1个奇偶校验位,不校验则不占用
1个停止位(如果开启校验位);或者2个停止位(如果没有校验)
校验方式纵向冗余校验(Longitudinal Redundancy Check,LRC)

注:ASCII模式用10位的时间来传输8位数据

在RTU(Remote Terminal Unit)模式下,每个字节可以传输两个十六进制字符,比如十六进制数0xAF,直接以十六进制0xAF(二进制:10101111)进行发送,因此它的发送密度比ASCII模式高一倍;RTU模式采用循环冗余校验(CRC),下面是对RTU模式的总结:

                                     Modbus协议RTU模式传输
  项目                                              描述
字符集16进制ASCII可打印字符0~9及A~F
每个16进制字符用一个字节内发送
每个字节1个起始位
8个数据位,LSB发送模式
1个奇偶校验位,不校验则不占用
1个停止位(如果开启校验位);或者2个停止位(如果没有校验)
校验方式循环冗余校验(Cyclical Redundancy Check,CRC)

注:RTU模式用11位的时间来传输8位数据

【限制】

  • Modbus是在1970年末为可编程逻辑控制器通信开发的,这些有限的数据类型在那个时代是可以被PLC理解的,大型二进制对象数据是不支持的。
  • 对节点而言,没有一个标准的方法找到数据对象的描述信息。
  • 由于Modbus是一个主/从协议,没有办法要求设备“报告异常”(构建在以太网的TCP/IP协议之上,被称为open-mbus除外)- 主节点必须循环的询问每个节点设备,并查找数据中的变化。在带宽可能比较宝贵的应用中,这种方式在应用中消耗带宽和网络时间,例如在低速率的无线链路上。
  • Modbus在一个数据链路上只能处理247个地址,这种情况限制了可以连接到主控站点的设备数量(以太网TCP/IP除外)。
  • Modbus传输在远端通讯设备之间缓冲数据的方式进行,有对通信一定是连续的限制,避免了传输中的缓冲区漏洞的问题。
  • Modbus协议针对未经授权的命令或截取数据并无安全性。

【功能码】

 功能码              名称                                      作用
01读取线圈状态取得一组逻辑线圈的当前状态(ON/OFF)
02读取输入状态取得一组开关输入的当前状态(ON/OFF)
03读取保持寄存器在一个或多个保持寄存器中取得当前的二进制值
04读取输入寄存器在一个或多个输入寄存器中取得当前的二进制值
05强置单线圈强置一个逻辑线圈的通断状态
06预置单寄存器把具体二进值装入一个保持寄存器
07读取异常状态取得8个内部线圈的通断状态,这8个线圈的地址由控制器决定,用户逻辑可以将这些线圈定义,以说明从机状态,短报文适宜于迅速读取状态
08回送诊断校验把诊断校验报文送从机,以对通信处理进行评鉴
09编程(只用于484)使主机模拟编程器作用,修改PC从机逻辑
10控询(只用于484)可使主机与一台正在执行长程序任务从机通信,探询该从机是否已完成其操作任务,仅在含有功能码9的报文发送后,本功能码才发送
11读取事件计数可使主机发出单询问,并随即判定操作是否成功,尤其是该命令或其他应答产生通信错误时
12读取通信事件记录可以是主机检索每台从机的ModBus事务处理通信事件记录。如果某项事务处理完成,记录会给出有关错误
13编程(184/384 484 584)可使主机模拟编程器功能修改PC从机逻辑
14探询(184/384 484 584)可使主机与正在执行任务的从机通信,定期控询该从机是否已完成其程序操作,仅在含有功能13的报文发送后,本功能码才可发送
15强置多线圈强置一串连续逻辑线圈的通断
16预置多寄存器把具体的二进制值装入一串连续的保持寄存器
17报告从机标识可使主机判断编址从机的类型及该从机运行指示灯的状态
18(884和MICRO 84)可使主机模拟编程功能,修改PC状态逻辑
19重置通信链路发生非可修改错误后,是从机复位于已知状态,可重置顺序字节
20读取通用参数(584L)显示扩展存储器文件中的数据信息
21写入通用参数(584L)把通用参数写入扩展存储文件,或修改之
22 ~ 64保留作扩展功能备用 
65 ~ 72保留以备用户功能所用留作用户功能的扩展编码
73 ~119非法功能 
120 ~ 127保留留作内部作用
128 ~ 255保留用于异常应答

参考链接1:https://zh.wikipedia.org/wiki/Modbus

参考链接2:https://wxs.me/807

参考链接3:https://zhuanlan.zhihu.com/p/29288329

Modbus协议深入讲解:http://www.ni.com/zh-cn/innovations/white-papers/14/the-modbus-protocol-in-depth.html

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Modbus协议多个分区,其中包括存储区、功能码和操作存储区的命令。 1. 存储区:Modbus协议定义了不同的存储区对象类型,包括线圈状态、输入线圈、输入寄存器和保持寄存器。每种存储区对象类型都有不同的访问类型和存储区标识。线圈状态和输入线圈是单个bit数据,可以读写。输入寄存器是16位字数据,只读。保持寄存器是16位字数据,可读可写。 2. 功能码:Modbus协议定义了一系列功能码,用于表示不同的操作。常见的功能码包括读取线圈状态、读取输入状态、读取保持寄存器、写单个线圈、写单个保持寄存器等。 3. 操作存储区的命令:Modbus协议中的功能码用于操作不同的存储区对象类型。例如,功能码01表示读取线圈状态,功能码02表示读取输入状态,功能码03表示读取保持寄存器,功能码04表示写单个保持寄存器,功能码05表示写单个线圈,功能码06表示写单个保持寄存器,功能码15表示写多个线圈,功能码16表示写多个保持寄存器。 因此,Modbus协议的分区包括存储区、功能码和操作存储区的命令。这些分区定义了不同的数据存储方式和操作方式,用于实现不同类型的通信和控制。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Modbus协议](https://blog.csdn.net/weixin_44881106/article/details/126379273)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [modbus协议简介](https://blog.csdn.net/shui12912/article/details/130039846)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Modbus协议与SerialPort端口读写](https://blog.csdn.net/Fu_Shi_rong/article/details/125181199)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值