当前位置: 首页 > news >正文

Modbus协议介绍

Modbus是一种串行通信协议,由Modicon公司(现为施耐德电气)在1979年为可编程逻辑控制器(PLC)通信而开发。它是工业自动化领域最常用的通信协议之一,具有开放性、简单性和跨平台兼容性,广泛应用于工业设备、楼宇自动化、电力系统等场景。 Modbus协议还遵循主从协议,支持单主机,多从机,最多支持247个从机设备。

一、Modbus协议基础特性

1. 物理层与传输模式

   物理接口:支持串口(RS-232、RS-485)和以太网(Modbus TCP)。  

   传输模式:  

       ASCII模式:消息以ASCII字符形式传输,每个字节包含两个ASCII字符(如`0x1F`表示为`31 46`),适合低速率通信。  

       RTU模式:消息以二进制形式传输,每个字节直接编码数据,效率更高,是最常用的模式。  

   以太网扩展**:Modbus TCP基于TCP/IP协议,使用502端口,简化了网络部署。

2. 通信方式

   主从架构:一个主设备(Master)发起通信,多个从设备(Slave)响应,从设备地址范围为1~247。  

   请求-响应机制:主设备发送请求,从设备根据请求返回数据或执行操作。从机不会主动进行数据的发送,从机之间也不会有通讯过程。

3. 数据模型  

    Modbus将设备数据抽象为四种基本寄存器类型:  

二、Modbus协议数据帧格式

1. RTU模式数据帧  

   帧结构:  

     [从机地址(1B)] [功能码(1B)] [数据(0~252B)] [CRC校验(2B)]  

  功能码(Function Code):标识操作类型,常见功能码:  

2.TCP模式数据帧

   在RTU帧基础上增加MBAP(Modbus Application Protocol)头:  

     [事务标识符(2B)] [协议标识符(2B,固定0)] [长度(2B)] [从机地址(1B)] [功能码(1B)] [数据(nB)]  

     事务标识符**:用于匹配请求和响应,由主设备生成。

三、Modbus通信流程示例

1. 主设备读取从设备温度值(HR寄存器)

   请求:  

     主→从:[从机地址=1] [功能码=03] [起始地址=0x0001] [寄存器数量=1]  

   响应:  

     从→主:[从机地址=1] [功能码=03] [字节数=2] [温度值=0x012C(300)]  

     解析:温度值为300,假设分辨率为0.1℃,则实际温度为30.0℃。

示例指令:

请求:01 01 00 00 00 0A BC 0D

含义:从机设备地址(01)+ 功能码(01)+ 起始寄存器完整地址(00 00)+ 线圈数量(00 0A)+ CRC16校验码(BC 0D)

解释:从地址为1的从机读取寄存器开始地址为1,连续读10个线圈。

应答:01 01 02 FF 03 B8 0D

含义:从机设备地址(01)+ 功能码(01)+ 数据字节数(02) + 读取到的数据内容(FF 03)+ CRC16校验码(B8 0D)

解释:从地址为1的从机中读取到两个字节的数据,读出的内容是FF 03。

2. 主设备控制从设备继电器(Coil)

   请求(闭合继电器):  

     主→从:[从机地址=2] [功能码=05] [线圈地址=0x0002] [值=0xFF00(ON)]   

   响应(成功):  

     从→主:[从机地址=2] [功能码=05] [线圈地址=0x0002] [值=0xFF00]  

     

四、Modbus协议优缺点

优点:

1. 简单易用:协议设计简洁,实现成本低,适合嵌入式系统。  

2. 开放性:无专利限制,免费使用,支持多种硬件平台。  

3. 跨平台兼容性:从单片机到工业PC均可实现,支持多种物理层。  

4. 广泛支持:几乎所有工业设备都提供Modbus接口(PLC、传感器、驱动器等)。  

缺点

1. 安全性弱:无加密机制,不适合安全敏感场景(需通过VPN等外部手段增强)。  

2. 单主架构限制:同一网络中只能有一个主设备,扩展性有限。  

3. 效率问题:每次通信需等待响应,不适合高并发场景。  

4. 数据量限制:单次请求最多传输253字节数据,大数据量需分批传输。  

五、Modbus协议变种与扩展

1. Modbus RTU/ASCII:基于串口的原始协议,使用CRC校验。  

2. Modbus TCP:基于以太网,使用MBAP头代替CRC校验,性能更高。  

3. Modbus PLUS:施耐德电气 proprietary 版本,支持多主架构,速率更高(1Mbps)。  

4. Modbus UDP:基于UDP协议,轻量但不可靠,适合实时性要求高的场景。  

5. Modbus over TLS:在TCP基础上增加TLS加密,提升安全性(如工业物联网场景)。  

六、Modbus应用场景

1. 工业自动化:PLC与传感器/执行器通信,如生产线监控、机器人控制。  

2. 楼宇自动化:HVAC系统、电梯控制、照明管理。  

3. 电力系统:电表数据采集、变电站监控、分布式能源管理。  

4. 智能交通:充电桩与电网通信、交通信号灯控制。  

5. 物联网(IoT):边缘设备与云端平台数据传输(通过网关转换协议)。  

七、Modbus实现注意事项

1. 错误处理:需处理超时、CRC校验失败、异常响应(功能码+0x80)等情况。  

2. 通信参数配置:主从设备波特率、奇偶校验、停止位必须一致。  

3. 网络拓扑:RS-485网络需注意终端电阻匹配、总线长度限制(通常≤1200米)。  

4. 性能优化:合理批量读取数据,减少请求次数;避免长耗时操作阻塞通信。  

、CRC16校验参考代码

//CRC校验

void CRC_Checkout_16(uint8_t *p_data,uint32_t data_len,uint8_t *data_crc) {

  uint16_t wcrc = 0xFFFF;

  uint8_t temp;

  uint32_t i=0,j=0;

  for(i=0;i<data_len;i++)

  {

    temp = *p_data & 0X00FF;

    p_data++;

    wcrc = wcrc^temp;

    for(j=0;j<8;j++)

    {

      if(wcrc & 0X0001)

      {

       wcrc>>=1;

        wcrc^=0XA001;

      }

      else

      {

        wcrc>>=1;

      }

     }

   }

  temp=wcrc;

  data_crc[0]=wcrc;

   data_crc[1]=wcrc>>8;

 return ;

  }

相关文章:

  • mac M2能安装的虚拟机和linux系统系统
  • 【时时三省】(C语言基础)字符数组的输入输出
  • 【C++进阶篇】多态
  • 使用Docker安装Dify
  • winreg查询Windows注册表的一些基本用法
  • 【Linux网络】————HTTP协议详解
  • 运算放大器相关的电路
  • Maven 项目中将本地依赖库打包到最终的 JAR 中
  • 【AI】mcp server是什么玩意儿
  • Python, FastAPI 与 RESTful API:构建高效 Web 服务的指南
  • SQLite 数据库常见问题及解决方法
  • 小结: Port Security,DHCP Snooping,IPSG,DAI,
  • 《汽车软件升级通用技术要求》 GB 44496-2024——解读
  • RN 鸿蒙混合开发实践(踩坑)
  • 每日Prompt:超现实交互场景
  • 动态网站 LNMP
  • 基于LNMP架构的个人博客系统部署
  • 详解RabbitMQ工作模式之通配符模式
  • laravel 中使用的pdf 扩展包 laravel-snappy(已解决中文乱码)
  • 从零搭建AI工作站:Gemma3大模型本地部署+WebUI配置全套方案
  • 港股持续拉升:恒生科技指数盘中涨幅扩大至6%,恒生指数涨3.3%
  • 上海护师邢红获第50届南丁格尔奖,她为何能摘得护理界最高荣誉
  • 巫蛊:文化的历史暗流
  • 国内首例侵入式脑机接口系统前瞻性临床试验:受试者已能用意念玩游戏
  • 郎朗也来了,在辰山植物园“轻松听古典”
  • 重庆一高校75万采购市价299元产品?工作人员:正在处理