0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【实用篇】ModbusTCP协议详解

工控论坛 来源:工控论坛 2024-01-14 11:13 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

概述

Modbus由MODICON公司于1979年开发,是一种工业现场总线协议标准。1996年施耐德公司推出基于以太网TCP/IP的Modbus协议:ModbusTCP。Modbus协议是一项应用层报文传输协议,包括ASCII、RTU、TCP三种报文类型。标准的Modbus协议物理层接口RS232RS422RS485和以太网接口,采用master/slave方式通信。 AModbus TCP数据帧 ModbusTCP的数据帧可分为两部分:MBAP+PDU。(一)报文头MBAP:MBAP为报文头,长度为7字节,组成如下:

25d87d9c-b21d-11ee-8b88-92fbcf53809c.png

25e2e750-b21d-11ee-8b88-92fbcf53809c.png

(二)帧结构PDU:PDU由功能码+数据组成。功能码为1字节,数据长度不定,由具体功能决定。

(1)功能码:Modbus的操作对象有四种:线圈、离散输入、保持寄存器、输入寄存器。

25ed2bc0-b21d-11ee-8b88-92fbcf53809c.png

(2)根据对象的不同,Modbus的功能码有:

25f11d52-b21d-11ee-8b88-92fbcf53809c.png

(3)说明更详细的表:

260752ac-b21d-11ee-8b88-92fbcf53809c.png

BPDU详细结构

(1)0x01:读线圈:在从站中读1~2000个连续线圈状态,ON=1,OFF=0

请求:MBAP 功能码 起始地址H 起始地址L 数量H 数量L(共12字节)

响应:MBAP 功能码 数据长度 数据(一个地址的数据为1位)

如:在从站0x01中,读取开始地址为0x0002的线圈数据,读0x0008位
00 01 00 00 00 06 01 01 00 02 00 08

回:数据长度为0x01个字节,数据为0x01,第一个线圈为ON,其余为OFF
00 01 00 00 00 04 01 01 01 01

(2)0x05:写单个线圈:将从站中的一个输出写成ON或OFF,0xFF00请求输出为ON,0x000请求输出为OFF。

请求:MBAP 功能码 输出地址H 输出地址L 输出值H 输出值L(共12字节)

响应:MBAP 功能码 输出地址H 输出地址L 输出值H 输出值L(共12字节)

如:将地址为0x0003的线圈设为ON
00 01 00 00 00 06 01 05 00 03 FF 00

回:写入成功
00 01 00 00 00 06 01 05 00 03 FF 00

(3)0x0F:写多个线圈:将一个从站中的一个线圈序列的每个线圈都强制为ON或OFF,数据域中置1的位请求相应输出位ON,置0的位请求响应输出为OFF。

请求:MBAP 功能码 起始地址H 起始地址L 输出数量H 输出数量L 字节长度 输出值H 输出值L

响应:MBAP 功能码 起始地址H 起始地址L 输出数量H 输出数量L

(4)0x02:读离散量输入:从一个从站中读1~2000个连续的离散量输入状态。

请求:MBAP 功能码 起始地址H 起始地址L 数量H 数量L(共12字节)

响应:MBAP 功能码 数据长度 数据(长度:9+ceil(数量/8))

如:从地址0x0000开始读0x0012个离散量输入
00 01 00 00 00 06 01 02 00 00 00 12

回:数据长度为0x03个字节,数据为0x01 04 00,表示第一个离散量输入和第11个离散量输入为ON,其余为OFF
00 01 00 00 00 06 01 02 03 01 04 00

(5)0x04:读输入寄存器:从一个远程设备中读1~2000个连续输入寄存器。

请求:MBAP 功能码 起始地址H 起始地址L 寄存器数量H 寄存器数量L(共12字节)

响应:MBAP 功能码 数据长度 寄存器数据(长度:9+寄存器数量×2)

如:读起始地址为0x0002,数量为0x0005的寄存器数据
00 01 00 00 00 06 01 04 00 02 00 05

回:数据长度为0x0A,第一个寄存器的数据为0x0c,其余为0x00
00 01 00 00 00 0D 01 04 0A 00 0C 00 00 00 00 00 00 00 00

(6)0x03:读保持寄存器:从远程设备中读保持寄存器连续块的内容。

请求:MBAP 功能码 起始地址H 起始地址L 寄存器数量H 寄存器数量L(共12字节)

响应:MBAP 功能码 数据长度 寄存器数据(长度:9+寄存器数量×2)

如:起始地址是0x0000,寄存器数量是 0x0003
00 01 00 00 00 06 01 03 00 00 00 03

回:数据长度为0x06,第一个寄存器的数据为0x21,其余为0x00
00 01 00 00 00 09 01 03 06 00 21 00 00 00 00

(7)0x06:写单个保持寄存器:在一个远程设备中写一个保持寄存器。

请求:MBAP 功能码 寄存器地址H 寄存器地址L 寄存器值H 寄存器值L(共12字节)

响应:MBAP 功能码 寄存器地址H 寄存器地址L 寄存器值H 寄存器值L(共12字节)

如:向地址是0x0000的寄存器写入数据0x000A
00 01 00 00 00 06 01 06 00 00 00 0A

回:写入成功
00 01 00 00 00 06 01 06 00 00 00 0A

(8)0x10:写多个保持寄存器:在一个远程设备中写连续寄存器块(1~123个寄存器)。

请求:MBAP 功能码 起始地址H 起始地址L 寄存器数量H 寄存器数量L 字节长度 寄存器值(13+寄存器数量×2)

响应:MBAP 功能码 起始地址H 起始地址L 寄存器数量H 寄存器数量L(共12字节)

如:向起始地址为0x0000,数量为0x0001的寄存器写入数据,数据长度为0x02,数据为0x000F
00 01 00 00 00 09 01 10 00 00 00 01 02 00 0F

回:写入成功
00 01 00 00 00 06 01 10 00 00 00 01

CModbus TCP示例报文

ModBusTcp与串行链路Modbus的数据域是一致的,具体数据域可以参考串行Modbus。这里给出几个ModbusTcp的链路解析说明,辅助新人分析报文。

261be500-b21d-11ee-8b88-92fbcf53809c.jpg

26206aa8-b21d-11ee-8b88-92fbcf53809c.jpg

263c2b26-b21d-11ee-8b88-92fbcf53809c.jpg

264fbe20-b21d-11ee-8b88-92fbcf53809c.jpg

DModbus TCP通信

(一)通信方式

Modbus设备可分为主站(poll)和从站(slave)。主站只有一个,从站有多个,主站向各从站发送请求帧,从站给予响应。在使用TCP通信时,主站为client端,主动建立连接;从站为server端,等待连接。

主站请求:功能码+数据

从站正常响应:请求功能码+响应数据

从站异常响应:异常功能码+异常码,其中异常功能码即将请求功能码的最高有效位置1,异常码指示差错类型

需要超时管理机制,避免无期限的等待可能不出现的应答

IANA(Internet Assigned Numbers Authority,互联网编号分配管理机构)给Modbus协议赋予TCP端口号为502,这是目前在仪表与自动化行业中唯一分配到的端口号。

(二)通信过程

connect 建立TCP连接

准备Modbus报文

使用send命令发送报文

在同一连接下等待应答

使用recv命令读取报文,完成一次数据交换

通信任务结束时,关闭TCP连接

E仿真软件

Modbus poll 和Modbus slave是一组Modbus仿真软件,可以实现Modbus RTU、TCP、串口仿真等。

仿真软件网址:https://modbustools.com/download.html

在ModbusTCP中,Modbus poll 作为客户端请求数据,Modbus slave 作为服务器端处理请求。

使用c语言编写客户端连接Modbus slave时,注意数据格式,一条指令一次性发出,否则连接会出错。

使用软件时,需要指定功能码,在setup->slave definition或者poll definition中进行设置。
– slave ID:从站编号(事务标识符)
– function:功能码,0x01对应线圈操作,0x02对应离散量操作,0x03对应保持寄存器操作,0x04对应输入寄存器操作
– address:开始地址
– quantity:寄存器/线圈/离散量 的数量

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

    关注

    31

    文章

    5627

    浏览量

    130981
  • MODBUS
    +关注

    关注

    28

    文章

    2583

    浏览量

    84271
  • 服务器
    +关注

    关注

    14

    文章

    10496

    浏览量

    91980

原文标题:【实用篇】ModbusTCP协议详解

文章出处:【微信号:gkongbbs,微信公众号:工控论坛】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    CAN转ModbusTCP需求靠它实现#plc

    ModbusTCP
    jf_68098288
    发布于 :2026年05月12日 09:30:46

    工业通信中,协议不匹配是常见问题,今天讲EtherCAT和ModbusTCP进行通讯。

    一个 EtherCAT 从站(如需级联) ModbusTCP 侧: NET 口接 ModbusTCP 设备(如变频器、仪表、上位机等) 电源:9-36V DC,支持冗余供电 2. 网页配置(TCP 侧) 连接
    的头像 发表于 05-11 14:34 138次阅读

    如何解决两台 S7-1200 与 DCS 通信:ModbusTCP 转 Profinet 网关方案

    系统作为ModbusTCP主站,能够提供ModbusTCP协议类型的数据,而现场的两台S7-300PLC采用Profinet协议,并作为Profinet主站。若要实现两台PLC与DCS
    的头像 发表于 05-07 17:32 1343次阅读
    如何解决两台 S7-1200 与 DCS 通信:<b class='flag-5'>ModbusTCP</b> 转 Profinet 网关方案

    ModbusRTU转ModbusTCP协议转换器有什么功能

    在工业物联网快速普及的今天,串口设备无法直接接入以太网仍是企业数字化升级的关键卡点。物通博联正式推出 WC112-轻量级的Modbus协议转化器,一款专为工业现场打造的串口转网口智能终端,助力用户
    的头像 发表于 03-27 16:05 399次阅读
    ModbusRTU转<b class='flag-5'>ModbusTCP</b><b class='flag-5'>协议</b>转换器有什么功能

    CAN转ModbusTCP网关:破解电池生产线设备协议壁垒,实现全链路智能互联

    工业通讯协议中,ModbusTCP作为一种常用的工业以太网协议,其易用性和通用性使得它成为连接不同设备和系统的理想选择。因此,无锡耐特森CAN转ModbusTCP
    的头像 发表于 01-14 15:43 305次阅读
    CAN转<b class='flag-5'>ModbusTCP</b>网关:破解电池生产线设备<b class='flag-5'>协议</b>壁垒,实现全链路智能互联

    ModbusTCP转CC-Link网关解锁直线电机性能上限

    的高效运行离不开稳定可靠的通讯系统,ModbusTCP转CClink网关在其中发挥着至关重要的作用。在内嵌式直线电机控制系统中,通常需要使用多种通信协议来满足不同的需求。ModbusTCP是一种常见
    的头像 发表于 12-22 11:46 354次阅读
    <b class='flag-5'>ModbusTCP</b>转CC-Link网关解锁直线电机性能上限

    工业电能无忧:ModbusTCP转EthernetIP精准护航电能质量

    深入探讨这种技术的核心原理以及其在实际应用中的重要性。让我们理解下什么是ModbusTCP和Ethernet/IP。ModbusTCP是一种通信协议,它基于以太网(Ethernet)并使用TCP/IP
    的头像 发表于 11-24 10:29 680次阅读

    无菌药厂变频升级方案:ModbusTCP转Canopen高效适配方案

    在现代工业自动化领域,无锡耐特森ModbusTCP转CanOpen协议转换网关发挥着至关重要的角色,特别是在诸如无菌药厂这样对环境要求极高的场合。ModbusTCP和CANopen是两种广泛
    的头像 发表于 11-18 17:03 676次阅读
    无菌药厂变频升级方案:<b class='flag-5'>ModbusTCP</b>转Canopen高效适配方案

    EtherNet/IP转MODBUSTCP协议转换网关实现HMI人机界面与分布式IO通讯的配置案例

    研华TPC-1581T型号(支持MODBUSTCP协议),分布式IO采用罗克韦尔Allen-Bradley1734-AENT型号(EtherNet/IP协议)。由于协议不兼容,导致设备
    的头像 发表于 09-05 11:25 1083次阅读
    EtherNet/IP转<b class='flag-5'>MODBUSTCP</b><b class='flag-5'>协议</b>转换网关实现HMI人机界面与分布式IO通讯的配置案例

    EthernetiP转modbusTCP网关在加氢催化中的应用

    ModbusTCP
    北京开疆智能技术有限公司
    发布于 :2025年07月24日 17:57:27

    Devicenet转ModbusTCP网关在工业中的应用分享

    ModbusTCP
    北京开疆智能技术有限公司
    发布于 :2025年07月15日 18:01:55

    降本增效Modbustcp转Devicenet网关的高效应用

    ModbusTCP
    北京开疆智能技术有限公司
    发布于 :2025年07月11日 16:27:04

    ModbusTCP转 Profinet网关:热收缩包装机智能化改造核心方案

    ModbusTCP
    无锡耐特森
    发布于 :2025年07月05日 14:59:49

    实现ModbusTCP转Profinet网关协议转换功能的网关设备

    ModbusTCP转Profinet网关产品主要功能 ModbusTCP转Profinet网关的核心功能为实现Profinet协议ModbusTCP
    的头像 发表于 07-01 11:58 795次阅读
    实现<b class='flag-5'>ModbusTCP</b>转Profinet网关<b class='flag-5'>协议</b>转换功能的网关设备

    开疆智能ModbusTCP转EtherCAT网关连接松下伺服案例

    使用什么功能都是共用一个IP。 二、ModbusTCP主站功能 三菱的PLC做ModbusTCP主站功能一般通过程序实现,需要用到“通信协议支持功能”。 1)在对象设备连接配置设置中添加“Active连接设备”选择“通信
    的头像 发表于 06-19 11:47 1088次阅读
    开疆智能<b class='flag-5'>ModbusTCP</b>转EtherCAT网关连接松下伺服案例