modbus通讯协议.docx
- 文档编号:9642855
- 上传时间:2023-05-20
- 格式:DOCX
- 页数:14
- 大小:43.93KB
modbus通讯协议.docx
《modbus通讯协议.docx》由会员分享,可在线阅读,更多相关《modbus通讯协议.docx(14页珍藏版)》请在冰点文库上搜索。
modbus通讯协议
Modbus通讯协议之南宫帮珍创作
创作时间:
二零二一年六月三十日
图片:
图片:
图片:
Modbus协议最初由Modicon公司开发出来,在1979年末该公司成为施耐德自动化(SchneiderAutomation)部份的一部份,现在Modbus已经是工业领域全球最流行的协议.此协议支持传统的RS-232、RS-422、RS-485和以太网设备.许多工业设备,包括PLC,DCS,智能仪表等都在使用Modbus协议作为他们之间的通讯标准.有了它,分歧厂商生产的控制设备可以连成工业网络,进行集中监控.当在网络上通信时,Modbus协议决定了每个控制器须要知道它们的设备地址,识别按地址发来的消息,决定要发生何种行动.如果需要回应,控制器将生成应答并使用Modbus协议发送给询问方.Modbus协议包括ASCII、RTU、TCP等,并没有规定物理层.此协议界说了控制器能够认识和使用的消息结构,而不论它们是经过何种网络进行通信的.标准的Modicon控制器使用RS232C实现串行的Modbus.Modbus的ASCII、RTU协议规定了消息、数据的结构、命令和就答的方式,数据通讯采纳Maser/Slave方式,Master端发出数据请求消息,Slave端接收到正确消息后就可以发送数据到Master端以响应请求;Master端也可以直接发消息修改Slave真个数据,实现双向读写.Modbus协议需要对数据进行校验,串行协议中除有奇偶校验外,ASCII模式采纳LRC校验,RTU模式采纳16位CRC校验,但TCP模式没有额外规定校验,因为TCP协议是一个面向连接的可靠协议.另外,Modbus采纳主从方式按时收发数据,在实际使用中如果某Slave站点断开后(如故障或关机),Master端可以诊断出来,而当故障修复后,网络又可自动接通.因此,Modbus协议的可靠性较好.下面我来简单的给年夜家介绍一下,对Modbus的ASCII、RTU和TCP协议来说,其中TCP和RTU协议非常类似,我们只要把RTU协议的两个字节的校验码去失落,然后在RTU协议的开始加上5个0和一个6并通过TCP/IP网络协议发送出去即可.所以在这里我仅介绍一下Modbus的ASCII和RTU协议.下表是ASCII协议和RTU协议进行的比力:
通过比力可以看到,ASCII协议和RTU协议相比拥有开始和结束标识表记标帜,因此在进行法式处置时能更加方便,而且由于传输的都是可见的ASCII字符,所以进行调试时就更加的直观,另外它的LRC校验也比力容易.可是因为它传输的都是可见的ASCII字符,RTU传输的数据每一个字节ASCII都要用两个字节来传输,比如RTU传输一个十六进制数0xF9,ASCII就需要传输’F’’9’的ASCII码0x39和0x46两个字节,这样它的传输的效率就比力低.所以一般来说,如果所需要传输的数据量较小可以考虑使用ASCII协议,如果所需传输的数据量比力年夜,最好能使用RTU协议.下面对两种协议的校验进行一下介绍.
1、LRC校验LRC域是一个包括一个8位二进制值的字节.LRC值由传输设备来计算并放到消息帧中,接收设备在接收消息的过程中计算LRC,并将它和接收到消息中LRC域中的值比力,如果两值不等,说明有毛病.LRC校验比力简单,它在ASCII协议中使用,检测了消息域中除开始的冒号及结束的回车换行号外的内容.它仅仅是把每一个需要传输的数据按字节叠加后取反加1即可.下面是它的VC代码:
BYTEGetCheckCode(constchar*pSendBuf,intnEnd)//获得校验码{BYTEbyLrc=0;charpBuf[4];intnData=0;for(i=1;i WORDGetCheckCode(constchar*pSendBuf,intnEnd)//获得校验码{WORDwCrc=WORD(0xFFFF);for(inti=0;i 2、{if(wCrc&1){ 3、wCrc>>=1;wCrc^=0xA001;}else{wCrc>>=1;}}}returnwCrc;}对一条RTU协议的命令可以简单的通过以下的步伐转化为ASCII协议的命令: 1、把命令的CRC校验去失落,而且计算出LRC校验取代.2、把生成的命令串的每一个字节转化成对应的两个字节的ASCII码,比如0x03转化成0x30,0x33(0的ASCII码和3的ASCII码).3、在命令的开头加上起始标识表记标帜“: ”,它的ASCII码为0x3A.4、在命令的尾部加上结束标识表记标帜CR,LF(0xD,0xA),此处的CR,LF暗示回车和换行的ASCII码.所以以下我们仅介绍RTU协议即可,对应的ASCII协议可以使用以上的步伐来生成.下表是Modbus支持的功能码: 在这些功能码中较长使用的是1、2、3、4、5、6号功能码,使用它们即可实现对下位机的数字量和模拟量的读写把持.1、读可读写数字量寄存器(线圈状态): 计算机发送命令: [设备地址][命令号01][起始寄存器地址高8位][低8位][读取的寄存器数高8位][低8位][CRC校验的低8位][CRC校验的高8位]例: [11][01][00][13][00][25][CRC低][CRC高]意义如下: <1>设备地址: 在一个485总线上可以挂接多个设备,此处的设备地址暗示想和哪一个设备通讯.例子中为想和17号(十进制的17是十六进制的11)通讯.<2>命令号01: 读取数字量的命令号固定为01.<3>起始地址高8位、低8位: 暗示想读取的开关量的起始地址(起始地址为0).比如例子中的起始地址为19.<4>寄存器数高8位、低8位: 暗示从起始地址开始读几多个开关量.例子中为37个开关量.<5>CRC校验: 是从开头一直校验到此之前.在此协议的最后再作介绍.此处需要注意,CRC校验在命令中的高低字节的顺序和其他的相反.设备响应: [设备地址][命令号01][返回的字节个数][数据1][数据2]...[数据n][CRC校验的低8位][CRC校验的高8位]例: [11][01][05][CD][6B][B2][0E][1B][CRC低][CRC高]意义如下: <1>设备地址和命令号和上面的相同.<2>返回的字节个数: 暗示数据的字节个数,也就是数据1,2...n中的n的值.<3>数据1...n: 由于每一个数据是一个8位的数,所以每一个数据暗示8个开关量的值,每一位为0暗示对应的开关断开,为1暗示闭合.比如例子中,暗示20号(索引号为19)开关闭合,21号断开,22闭合,23闭合,24断开,25断开,26闭合,27闭合...如果询问的开关量不是8的整倍数,那么最后一个字节的高位部份无意义,置为0.<4>CRC校验同上.2、读只可读数字量寄存器(输入状态): 和读取线圈状态类似,只是第二个字节的命令号不再是1而是2.3、写数字量(线圈状态): 计算机发送命令: [设备地址][命令号05][需下置的寄存器地址高8位][低8位][下置的数据高8位][低8位][CRC校验的低8位][CRC校验的高8位]例: [11][05][00][AC][FF][00][CRC低][CRC高]意义如下: <1>设备地址和上面的相同.<2>命令号: 写数字量的命令号固定为05.<3>需下置的寄存器地址高8位,低8位: 标明了需要下置的开关的地址.<4>下置的数据高8位,低8位: 标明需要下置的开关量的状态.例子中为把该开关闭合.注意,此处只可以是[FF][00]暗示闭合[00][00]暗示断开,其他数值非法.<5>注意此命令一条只能下置一个开关量的状态.设备响应: 如果胜利把计算机发送的命令原样返回,否则不响应.4、读可读写模拟量寄存器(坚持寄存器): 计算机发送命令: [设备地址][命令号03][起始寄存器地址高8位][低8位][读取的寄存器数高8位][低8位][CRC校验的低8位][CRC校验的高8位]例: [11][03][00][6B][00][03][CRC低][CRC高]意义如下: <1>设备地址和上面的相同.<2>命令号: 读模拟量的命令号固定为03.<3>起始地址高8位、低8位: 暗示想读取的模拟量的起始地址(起始地址为0).比如例子中的起始地址为107.<4>寄存器数高8位、低8位: 暗示从起始地址开始读几多个模拟量.例子中为3个模拟量.注意,在返回的信息中一个模拟量需要返回两个字节.设备响应: [设备地址][命令号03][返回的字节个数][数据1][数据2]...[数据n][CRC校验的低8位][CRC校验的高8位]例: [11][03][06][02][2B][00][00][00][64][CRC低][CRC高]意义如下: <1>设备地址和命令号和上面的相同.<2>返回的字节个数: 暗示数据的字节个数,也就是数据1,2...n中的n的值.例子中返回了3个模拟量的数据,因为一个模拟量需要2个字节所以共6个字节.<3>数据1...n: 其中[数据1][数据2]分别是第1个模拟量的高8位和低8位,[数据3][数据4]是第2个模拟量的高8位和低8位,以此类推.例子中返回的值分别是555,0,100.<4>CRC校验同上.5、读只可读模拟量寄存器(输入寄存器): 和读取保管寄存器类似,只是第二个字节的命令号不再是2而是4.6、写单个模拟量寄存器(坚持寄存器): 计算机发送命令: [设备地址][命令号06][需下置的寄存器地址高8位][低8位][下置的数据高8位][低8位][CRC校验的低8位][CRC校验的高8位]例: [11][06][00][01][00][03][CRC低][CRC高]意义如下: <1>设备地址和上面的相同.<2>命令号: 写模拟量的命令号固定为06.<3>需下置的寄存器地址高8位,低8位: 标明了需要下置的模拟量寄存器的地址.<4>下置的数据高8位,低8位: 标明需要下置的模拟量数据.比如例子中就把1号寄存器的值设为3.<5>注意此命令一条只能下置一个模拟量的状态.设备响应: 如果胜利把计算机发送的命令原样返回,否则不响应. mym 级别: 总版主精华: 41发帖: 3956威望: 9957点金钱: 9431Gold贡献值: 601点朋友圈: ifix技术群在线时间: 539(小时)注册时间: 2005-02-02最后登录: 2008-01-25 Modbus通讯协议 MODBUS通讯协议简介工业控制已从单机控制走向集中监控、集散控制,如今已进入网络时代,工业控制器连网也为网络管理提供了方便.Modbus就是工业控制器的网络协议中的一种.一、概述Modbus协议是应用于电子控制器上的一种通用语言.通过此协议,控制器相互之间、控制器经由网络(例如以太网)和其它设备之间可以通信.它已经成为一通用工业标准.有了它,分歧厂商生产的控制设备可以连成工业网络,进行集中监控.此协议界说了一个控制器能认识使用的消息结构,而不论它们是经过何种网络进行通信的.它描述了一控制器请求访问其它设备的过程,如果回应来自其它设备的请求,以及怎样侦测毛病并记录.它制定了消息域格局和内容的公共格式.当在一Modbus网络上通信时,此协议决定了每个控制器须要知道它们的设备地址,识别按地址发来的消息,决定要发生何种行动.如果需要回应,控制器将生成反馈信息并用Modbus协议发出.在其它网络上,包括了Modbus协议的消息转换为在此网络上使用的帧或包结构.这种转换也扩展了根据具体的网络解决节地址、路由路径及毛病检测的方法.1、在Modbus网络上转输标准的Modbus口是使用一RS-232C兼容串行接口,它界说了连接口的针脚、电缆、信号位、传输波特率、奇偶校验.控制器能直接或经由Modem组网.控制器通信使用主—从技术,即仅一设备(主设备)能初始化传输(查询).其它设备(从设备)根据主设备查询提供的数据作出相应反应.典范的主设备: 主机和可编程仪表.典范的从设备: 可编程控制器.主设备可独自和从设备通信,也能以广播方式和所有从设备通信.如果独自通信,从设备返回一消息作为回应,如果是以广播方式查询的,则不作任何回应.Modbus协议建立了主设备查询的格式: 设备(或广播)地址、功能代码、所有要发送的数据、一毛病检测域.从设备回应消息也由Modbus协议构成,包括确认要行动的域、任何要返回的数据、和一毛病检测域.如果在消息接收过程中发生一毛病,或从设备不能执行其命令,从设备将建立一毛病消息并把它作为回应发送出去.2、在其它类型网络上转输在其它网络上,控制器使用对等技术通信,故任何控制都能初始和其它控制器的通信.这样在独自的通信过程中,控制器既可作为主设备也可作为从设备.提供的多个内部通道可允许同时发生的传输进程.在消息位,Modbus协议仍提供了主—从原则,尽管网络通信方法是“对等”.如果一控制器发送一消息,它只是作为主设备,并期望从从设备获得回应.同样,当控制器接收到一消息,它将建立一从设备回应格式并返回给发送的控制器.Modbus是Modicon公司为其PLC与主机之间的通讯而发明的串行通讯协议.其物理层采纳RS232、485等异步串行标准.由于其开放性而被年夜量的PLC及RTU厂家采纳.Modbus通讯方式采纳主从方式的查询-相应机制,只有主站发出查询时,从站才华给出响应,从站不能主动发送数据.主站可以向某一个从站发出查询,也可以向所有从站广播信息.从站只响应独自发给它的查询,而不响应广播消息.Modbus的串行口的通讯参数(如波特率、奇偶校验)可由用户选择.二、MODBUS协议传送方式MODBUS通讯协议有两种传送方式: RTU方式和ASCII方式,两种方式如下所示: 项目RTU方式ASCII方式字节长度8BITS7BITS奇偶校验1BITOR0BIT1BITOR0BIT字节中止1BITOR2BITS1BITOR2BITS开始标识表记标帜不要: (冒号)结束标识表记标帜不要CR,LF数据间隔<24BIT<1S犯错检验方式CRC-16LRC控制器能设置为两种传输模式(ASCII或RTU)中的任何一种在标准的Modbus网络通信.用户选择想要的模式,包括串口通信参数(波特率、校验方式等),在配置每个控制器的时候,在一个Modbus网络上的所有设备都必需选择相同的传输模式和串口参数.三、Modbus消息帧两种传输模式中(ASCII或RTU),传输设备以将Modbus消息转为有起点和终点的帧,这就允许接收的设备在消息起始处开始工作,读地址分配信息,判断哪一个设备被选中(广播方式则传给所有设备),判知何时信息已完成.部份的消息也能侦测到而且毛病能设置为返回结果.1、ASCII帧使用ASCII模式,消息以冒号(: )字符(ASCII码3AH)开始,以回车换行符结束(ASCII码0DH,0AH).其它域可以使用的传输字符是十六进制的0...9,A...F.网络上的设备不竭侦测“: ”字符,当有一个冒号接收到时,每个设备都解码下个域(地址域)来判断是否发给自己的.消息中字符间发送的时间间隔最长不能超越1秒,否则接收的设备将认为传输毛病.2、RTU帧使用RTU模式,消息发送至少要以3.5个字符时间的停顿间隔开始.在网络波特率下多样的字符时间,这是最容易实现的(如下图的T1-T2-T3-T4所示).传输的第一个域是设备地址.可以使用的传输字符是十六进制的0...9,A...F.网络设备不竭侦测网络总线,包括停顿间隔时间内.当第一个域(地址域)接收到,每个设备都进行解码以判断是否发往自己的.在最后一个传输字符之后,一个至少3.5个字符时间的停顿标定了消息的结束.一个新的消息可在此停顿后开始.整个消息帧必需作为一连续的流转输.如果在帧完成之前有超越1.5个字符时间的停登时间,接收设备将刷新不完整的消息并假定下一字节是一个新消息的地址域.同样地,如果一个新消息在小于3.5个字符时间内接着前个消息开始,接收的设备将认为它是前一消息的延续.这将招致一个毛病,因为在最后的CRC域的值不成能是正确的.3、地址域消息帧的地址域包括两个字符(ASCII)或8Bit(RTU).可能的从设备地址是0...247(十进制).单个设备的地址范围是1...247.主设备通过将要联络的从设备的地址放入消息中的地址域来选通从设备.当从设备发送回应消息时,它把自己的地址放入回应的地址域中,以便主设备知道是哪一个设备作出回应.地址0是用作广播地址,以使所有的从设备都能认识.当Modbus协议用于更高水准的网络,广播可能不允许或以其它方式取代.4、如何处置功能域消息帧中的功能代码域包括了两个字符(ASCII)或8Bits(RTU).可能的代码范围是十进制的1...255.固然,有些代码是适用于所有控制器,有此是应用于某种控制器,还有些保管以备后用.当消息从主设备发往从设备时,功能代码域将告之从设备需要执行哪些行为.例如去读取输入的开关状态,读一组寄存器的数据内容,读从设备的诊断状态,允许调入、记录、校验在从设备中的法式等.当从设备回应时,它使用功能代码域来指示是正常回应(无误)还是有某种毛病发生(称作异议回应).对正常回应,从设备仅回应相应的功能代码.对异议回应,从设备返回一同等于正常代码的代码,但最重要的位置为逻辑1.例如: 一从主设备发往从设备的消息要求读一组坚持寄存器,将发生如下功能代码: 00000011(十六进制03H)对正常回应,从设备仅回应同样的功能代码.对异议回应,它返回: 10000011(十六进制83H)除功能代码因异议毛病作了修改外,从设备将一共同的代码放到回应消息的数据域中,这能告诉主设备发生了什么毛病.主设备应用法式获得异议的回应后,典范的处置过程是重发消息,或者诊断发给从设备的消息并陈说给把持员.5、数据域数据域是由两个十六进制数集合构成的,范围00...FF.根据网络传输模式,这可以是由一对ASCII字符组成或由一RTU字符组成.从主设备发给从设备消息的数据域包括附加的信息: 从设备必需用于进行执行由功能代码所界说的所为.这包括了象不连续的寄存器地址,要处置项的数目,域中实际数据字节数.例如,如果主设备需要从设备读取一组坚持寄存器(功能代码03),数据域指定了起始寄存器以及要读的寄存器数量.如果主设备写一组从设备的寄存器(功能代码10十六进制),数据域则指明了要写的起始寄存器以及要写的寄存器数量,数据域的数据字节数,要写入寄存器的数据.如果没有毛病发生,从从设备返回的数据域包括请求的数据.如果有毛病发生,此域包括一异议代码,主设备应用法式可以用来判断采用下一步行动.在某种消息中数据域可以是不存在的(0长度).例如,主设备要求从设备回应通信事件记录(功能代码0B十六进制),从设备不需任何附加的信息.6、毛病检测域标准的Modbus网络有两种毛病检测方法.毛病检测域的内容视所选的检测方法而定.ASCII被选用ASCII模式作字符帧,毛病检测域包括两个ASCII字符.这是使用LRC(纵向冗长检测)方法抵消息内容计算得出的,不包括开始的冒号符及回车换行符.LRC字符附加在回车换行符前面.RTU被选用RTU模式作字符帧,毛病检测域包括一16Bits值(用两个8位的字符来实现).毛病检测域的内容是通过抵消息内容进行循环冗长检测方法得出的.CRC域附加在消息的最后,添加时先是低字节然后是高字节.故CRC的高位字节是发送消息的最后一个字节.7、字符的连续传输当消息在标准的Modbus系列网络传输时,每个字符或字节以如下方式发送(从左到右): 最低有效位...最高有效位四、毛病检测方法标准的Modbus串行网络采纳两种毛病检测方法.奇偶校验对每个字符都可用,帧检测(LRC或CRC)应用于整个消息.它们都是在消息发送前由主设备发生的,从设备在接收过程中检测每个字符和整个消息帧.用户要给主设备配置一预先界说的超时时间间隔,这个时间间隔要足够长,以使任何从设备都能作为正常反应.如果从设备测到一传输毛病,消息将不会接收,也不会向主设备作出回应.这样超时事件将触发主设备来处置毛病.发往不存在的从设备的地址也会发生超时.1、奇偶校验用户可以配置控制器是奇或偶校验,或无校验.这将决定了每个字符中的奇偶校验位是如何设置的.如果指定了奇或偶校验,“1”的位数将算到每个字符的位数中(ASCII模式7个数据位,RTU中8个数据位).例如RTU字符帧中包括以下8个数据位: 11000101整个“1”的数目是4个.如果便用了偶校验,帧的奇偶校验位将是0,便得整个“1”的个数仍是4个.如果便用了奇校验,帧的奇偶校验位将是1,便得整个“1”的个数是5个.如果没有指定奇偶校验位,传输时就没有校验位,也不进行校验检测.取代一附加的停止位填充至要传输的字符帧中.2、LRC检测使用ASCII模式,消息包括了一基于LRC方法的毛病检测域.LRC域检测了消息域中除开始的冒号及结束的回车换行号外的内容.LRC域是一个包括一个8位二进制值的字节.LRC值由传输设备来计算并放到消息帧中,接收设备在接收消息的过程中计算LRC,并将它和接收到消息中LRC域中的值比力,如果两值不等,说明有毛病.LRC方法是将消息中的8Bit的字节连续累加,抛弃了进位.LRC简单函数如下: staticunsignedcharLRC(auchMsg,usDataLen)unsignedchar*auchMsg;/*要进行计算的消息*/unsignedshortusData
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- modbus 通讯 协议
文档标签
- 基于MODBUS协议通讯
- modbus协议
- ModBusRTU通讯协议
- 工业通讯协议
- UNTMMIB通讯协议U24COMV100通讯协议
- opc通讯协议
- 中文通讯协议
- PMAC802MODBUS通讯协议V10
- MODBUS通讯协议RTU
- Modbus协议
- OmronFins通讯协议Fins通讯
- abplcmodbus通讯modbus
- modbus通讯协议
- 通讯协议v41
- Modbus通讯协议编程
- LISHL通讯协议
- 基于CP430MODBUS通讯
- 基于USS协议MCGS
- 基于DLNAGENA协议
- 基于POP3SMTP协议
- 基于wiresharkHTTP协议
- MODBUS协议测温系统
- 基于ProfibusDP协议
- 基于MODBUS协议上位