modbus协议.docx

上传人:b****1 文档编号:700980 上传时间:2022-10-12 格式:DOCX 页数:31 大小:56.87KB
下载 相关 举报
modbus协议.docx_第1页
第1页 / 共31页
modbus协议.docx_第2页
第2页 / 共31页
modbus协议.docx_第3页
第3页 / 共31页
modbus协议.docx_第4页
第4页 / 共31页
modbus协议.docx_第5页
第5页 / 共31页
点击查看更多>>
下载资源
资源描述

modbus协议.docx

《modbus协议.docx》由会员分享,可在线阅读,更多相关《modbus协议.docx(31页珍藏版)》请在冰豆网上搜索。

modbus协议.docx

modbus协议

MODBUS规约中文说明书

MODBUS规约

MODBUS规约是MODICOM公司开发的一个为很多厂商支持的开放规约

Modbus协议是应用于电子控制器上的一种通用语言。

通过此协议,控制器相互之间、控制器经由网络(例如以太网)和其它设备之间可以通信。

它已经成为一通用工业标准。

有了它,不同厂商生产的控制设备可以连成工业网络,进行集中监控。

此协议定义了一个控制器能认识使用的消息结构,而不管它们是经过何种网络进行通信的。

它描述了控制器请求访问其它设备的过程,如果回应来自其它设备的请求,以及怎样侦测错误并记录。

它制定了消息域格局和内容的公共格式。

当在Modbus网络上通信时,此协议决定了每个控制器须要知道它们的设备地址,识别按地址发来的消息,决定要产生何种行动。

如果需要回应,控制器将生成反馈信息并用Modbus协议发出。

在其它网络上,包含了Modbus协议的消息转换为在此网络上使用的帧或包结构。

这种转换也扩展了根据具体的网络解决节地址、路由路径及错误检测的方法。

标准的Modbus口是使用RS-232C兼容串行接口,它定义了连接口的针脚、电缆、信号位、传输波特率、奇偶校验。

控制器能直接或经由Modem组网。

控制器通信使用主—从技术,即仅设备(主设备)能初始化传输(查询)。

其它设备(从设备)根据主设备查询提供的数据做出相应反应。

典型的主设备:

主机和可编程仪表。

典型的从设备:

可编程控制器。

主设备可单独和从设备通信,也能以广播方式和所有从设备通信。

如果单独通信,从设备返回消息作为回应,如果是以广播方式查询的,则不作任何回应。

Modbus协议建立了主设备查询的格式:

设备(或广播)地址、功能代码、所有要发送的数据、错误检测域。

从设备回应消息也由Modbus协议构成,包括确认要行动的域、任何要返回的数据、和错误检测域。

如果在消息接收过程中发生错误,或从设备不能执行其命令,从设备将建立错误消息并把它作为回应发送出去。

在其它网络上,控制器使用对等技术通信,故任何控制都能初始和其它控制器的通信。

这样在单独的通信过程中,控制器既可作为主设备也可作为从设备。

提供的多个内部通道可允许同时发生的传输进程。

在消息位,Modbus协议仍提供了主—从原则,尽管网络通信方法是“对等”。

如果控制器发送消息,它只是作为主设备,并期望从从设备得到回应。

同样,当控制器接收到消息,它将建立一从设备回应格式并返回给发送的控制器。

.主设备查询

查询消息中的功能代码告之被选中的从设备要执行何种功能。

数据段包含了从设备要执行功能的任何附加信息。

例如功能代码03是要求从设备读保持寄存器并返回它们的内容。

数据段必须包含要告之从设备的信息:

从何寄存器开始读及要读的寄存器数量。

错误检测域为从设备提供了一种验证消息内容是否正确的方法。

.从设备回应

如果从设备产生正常的回应,在回应消息中的功能代码是在查询消息中的功能代码的回应。

数据段包括了从设备收集的数据:

像寄存器值或状态。

如果有错误发生,功能代码将被修改以用于指出回应消息是错误的,同时数据段包含了描述此错误信息的代码。

错误检测域允许主设备确认消息内容是否可用。

每个MODBUS帧都包括地址域功能域数据域错误检测域

RTU方式

地址

功能代码

数据数量

数据1

...

数据n

CRC高字节

CRC低字节

地址域功能域数据域错误检测域

帧定界:

MODBUSRTU方式下,每两个字符之间发送或者接收的时间间隔不能超过1.5倍字符传输时间。

如果两个字符时间间隔超过了3.5倍的字符传输时间,规约就认为一帧数据已经接收,新的一帧数据传输开始。

 

ASCII方式

ASCII模式

:

地址

功能代码

数据数量

数据1

...

数据n

LRC高字节

LRC低字节

回车

换行

地址域功能域数据域错误检测域

帧定界:

“:

”帧起始“CRLF”帧结束

ASCII方式用两个ASCII字符表示一个8位数据,比如16进制的3A用字符“3”和字符“A”表示。

MODBUSTCP

MODBUSTCP模式下,由于模块的地址由IP地址确定,所以不再有地址域内容,考虑到TCP网络是可靠的数据传输网络,故不再有校验数据。

但是考虑到在IP网上数据到达的顺序可能与我们预期的数据不一致,故增加了一个数据序号,考虑到在MODBUSTCP协议上承载MODBUS协议,还在头部数据中增加了一个地址域。

MODBUSTCP/MODBUS桥

STC-511可以用于MODBUSTCP到MODBUS的桥设备使用,作为MODBUS桥设备时,需要在地址域上加上地址,另外对应的串口需要设置为MODBUS主设备。

由于存在两个串口设备,地址域的最高位MSB=1则访问串口2,MSB=0则访问串口1。

地址域广播地址是把低7位全部置为1,在发送到MODBUS总线时,地址修改为0。

地址域为0表示不访问MODBUS串口设备。

支持命令

我们目前所支持的功能码非常有限,主要包括:

01READCOILSTATUS

02READINPUTSTATUS

03READHOLDINGREGISTERS

04READINPUTREGISTERS

05FORCESINGLECOIL

06PRESETSINGLEREGISTER

15FORCEMULTIPLECOILS

16FORCEMULTIPLEREGISTERS

20READFILERECORD

21WRITEFILERECORD

24READFIFOQUEUE

读继电器状态

功能码:

01

数据起始地址:

00001~00008

数据长度:

不大于08(因为只有8个输出继电器)

说明:

读取输出继电器的状态。

数据说明:

地址

描述

说明

00001

第1个输出继电器

=1吸合=0断开

00002

第2个输出继电器

=1吸合=0断开

00003

第3个输出继电器

=1吸合=0断开

00004

第4个输出继电器

=1吸合=0断开

00005

第5个输出继电器

=1吸合=0断开

00006

第6个输出继电器

=1吸合=0断开

00007

第7个输出继电器

=1吸合=0断开

00008

第8个输出继电器

=1吸合=0断开

00009

第9个输出继电器(虚拟)

=1吸合=0断开

00010

第10个输出继电器(虚拟)

=1吸合=0断开

00011

第11个输出继电器(虚拟)

=1吸合=0断开

00012

第12个输出继电器(虚拟)

=1吸合=0断开

00013

第13个输出继电器(虚拟)

=1吸合=0断开

00014

第14个输出继电器(虚拟)

=1吸合=0断开

00015

第15个输出继电器(虚拟)

=1吸合=0断开

00016

第16个输出继电器(虚拟)

=1吸合=0断开

MODBUS请求

功能码

1BYTE

0X01

起始地址

2BYTE

0X0000TO0XFFFF

读取数量

2BYTE

1TO2000(0X7D0)

MODBUS响应

功能码

1BYTE

0X01

字节计数

1BYTE

N

线圈状态

nBYTE

n=NorN+1

N=读取数量/8如果余数不为0则N=N+1

错误响应

功能码

1BYTE

0X01+0X80

错误代码

1BYTE

0x1or0x2or0x3or0x4

举例

请求

响应

域名称

数据(hex)

域名称

数据(hex)

功能码

01

功能码

01

起始地址高(字节)

00

字节计数

03

起始地址低(字节)

13

27(h)~20状态

CD

读取数量高(字节)

00

35(h)~28状态

6B

读取数量低(字节)

13

38(h)~36状态

05

读开关量输入

功能码:

02

数据起始地址:

100001~1000016

数据长度:

不大于16(因为只有16路输入)

说明:

读取输入开关量的状态。

输入的量改变状态需要经过0.1S滤波抗干扰后才会变化。

如果用户想知道改变的时刻,需要读取系统的FIFO中的SOE事件记录或者读取文件中的SOE记录。

输入量的每次改变都会累积到该路对应的32位计数器上,对于计数,输入的最高频率可以是1KHz。

数据说明:

地址

描述

说明

100001

第1路开关量状态

=0没有通电=1接通电源

100002

第2路开关量状态

=0没有通电=1接通电源

100003

第3路开关量状态

=0没有通电=1接通电源

100004

第4路开关量状态

=0没有通电=1接通电源

100005

第5路开关量状态

=0没有通电=1接通电源

100006

第6路开关量状态

=0没有通电=1接通电源

100007

第7路开关量状态

=0没有通电=1接通电源

100008

第8路开关量状态

=0没有通电=1接通电源

100009

第9路开关量状态

=0没有通电=1接通电源

100010

第10路开关量状态

=0没有通电=1接通电源

100011

第11路开关量状态

=0没有通电=1接通电源

100012

第12路开关量状态

=0没有通电=1接通电源

100013

第13路开关量状态

=0没有通电=1接通电源

100014

第14路开关量状态

=0没有通电=1接通电源

100015

第15路开关量状态

=0没有通电=1接通电源

100016

第16路开关量状态

=0没有通电=1接通电源

MODBUS请求

功能码

1BYTE

0X02

起始地址

2BYTE

0X0000TO0XFFFF

读取数量

2BYTE

1TO2000(0X7D0)

MODBUS响应

功能码

1BYTE

0X02

字节计数

1BYTE

N

输入状态

nBYTE

n=NorN+1

N=读取数量/8如果余数不为0则N=N+1

错误响应

功能码

1BYTE

0X02+0X80

错误代码

1BYTE

0x1or0x2or0x3or0x4

举例

请求

响应

域名称

数据(hex)

域名称

数据(hex)

功能码

02

功能码

02

起始地址高(字节)

00

字节计数

03

起始地址低(字节)

C4

204(h)~197状态

AC

读取数量高(字节)

00

212(h)~205状态

DB

读取数量低(字节)

16

218(h)~213状态

35

读保持寄存器

功能码:

03

数据起始地址:

400001-400128

数据长度:

不大于125(因为通信缓冲区的限制)

说明:

读取保持寄存器的值。

读取的是16位整数或者无符合整数。

地址

描述

说明

400001

当日时间

系统当日毫秒时钟低16位

400002

当日时间

系统当日毫秒时钟高16位

400003

当日时间

系统日期低16位

400004

当日时间

系统日期高1

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 职业规划

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1