当前位置:首页 > 物联网 > 《物联网技术》杂志
[导读]摘要:提出了一种基于RTU油井远程测控系统的数据采集和传输层软件设计方案。介绍了实现各种传感器的数据采集、传输以及外部继电器控制的软件设计方法,并对实现Modbus/RTU和Modbus/TCP的通信进行了详细分析。分析结果显示:通过软件配置,可实现多种工作方式,有利于该系统在不同场合下的应用。

引言

每一个油田都拥有众多的油气井,并且分布在山川旷野里,油气井的管理方式多为由人工每日值守,定时检査设备运行情况,记录相关数据。这种方式增加了用工人数,加大了护井工劳动强度,最重要的是影响对设备的监控。当抽油机、电泵出现微小故障时,往往很难被人工及时发现,从而得不到有效地防护与控制

为了能有效地发现油井、地层、油藏的变化,可用油井远程测控系统,通过在抽油机上安装位移传感器和载荷传感器,检测抽油机的工况,实时在线监测抽油机工作参数,及时发现故障并报警,及时维护。本文提出了一种基于RTU的油井远程测控系统的数据釆集与传输层设计方案,并将该方案用于实际的井场应用中。

1  油井远程测控系统总体架构

油井远程测控系统的总体架构如图1所示,整个测控系统的组网架构分为现场局域网、企业信息网两大部分。网络拓扑釆用分层星型拓扑,是为了在中央测控室的中央测控服务器与现场局域网的各个测控代理服务器的测控对象之间建立更有效的连接方式。每个测控分站设测控代理服务器,实时发送或读取的井场设备数据先经测控代理服务器处理后再并行传输到中央测控服务器,这样既让等级高的设备预警信号得到现场级的及时响应,又减轻了中央测控服务器处理数据的压力。WEB服务器与中央测控服务器通过数据库服务器连接,这种连接方式使WEB服务器面向的对象是数据库服务器,有利于WEB服务器在处理管理用户的指令时与中央监控服务器保持一定的时差,避免了相互动作间的冲突。而所有这些数据来自于代理测控服务器通过井场数据采集与传输层得到的OIT目前最常见的数据采集与传输层的工作方式有图1所示的两种情况。其中井场1针对安装多个传感器的油气井,在每个油气井处安装一个RTU从站,能够对该油气井的传感器进行统一管理,并在每个井场设置一个RTU主站,釆用主叫/从响应的方式,采集各从站的传感器数据,然后将各从站数据上传到上位机(测控代理服务器);井场2针对安装几个传感器的油气井,在每个井场放置一个RTU,直接将传感器的数据采集后发送到上位机;为了能够兼容这两种工作方式,本文设计了一个基于RTU的数据采集与传输层系统软件。

基于RTU油井远程测控系统的数据采集与传输层软件设计

2  数据采集与传输层硬件基础——RTU

有些油气田由于地理原因,不易铺设电缆,本系统引入物联网技术,加入无线通信ZigBee模块,并利用其自组织原理,实现在井场无线自组织寻址和数据传输,可以简单、方便地实现井场实时数据采集,利用这些有效数据指导油田油气生产,提高产量,其构成一个物联网回路,改变了油田生产方式。

油井远程测控系统RTU采用Samsung公司的S3C2440A,具有400MHz的工作频率,主要控制数据流的输入输出;采用具有2Mb存储能力的Norflash(EN29LV160AB)存储程序;用有128Mb存储能力的Nandflash(K9F2G08U0B)存储数据;利用AD转换器ADS7952釆集8通道12位模拟数据;系统环境温度由温度传感器TMP100获得;考虑到ZigBee模块的接口以及有线方式下的长距离传输等因素,RTU的串行链路口为RS232及RS485;为与代理测控服务器PC机相连,RTU采用DM9000实现以太网连接;RTU的初始配置信息采用矽PROM存储;RTU内还包含隔离电路、控制单元等几个部分。RTU的硬件框图如图2所示。

基于RTU油井远程测控系统的数据采集与传输层软件设计

3  数据釆集与传输层系统软件

数据采集与传输层通信协议

Modbus通信协议已经非常广泛地应用于自动控制和通信领域中,通过此协议,控制器相互之间、控制器经由网络(例如以太网)和其它设备之间可以实现通信。Modbus网络属于一种主从网络,允许一个主站和一个或多个从站通信。它采用命令/应答方式,每种命令报文都对应着一种应答报文。网络中的每个从站都必须分配一个唯一的地址。主站发出的命令中含有要求访问的从站地址,只有具有该地址的从站才会对该命令响应。

3.1.1  Modbus/RTU通信协议

RTU主/从站串口通信时,通常使用的是Modbus/RTU传输模式。在Modbus报文RTU帧中,如果两个字符之间的空闲间隔大于1.5个字符时间,那就认为报文帧不完整,此时接收站应该丢弃这个报文。时长至少为3.5个字符时间的空闲间隔将报文帧区分。RTU消息帧的典型格式如表1所列。

表1  Modbus/RTU消息帧典型格式

地址设备
功能码
数据
CRC校验
8bits
8bits
8nbits
16bits

3.1.2  Modbus/TCP通信协议

Modbus/TCP是一种应用层的协议,上层为Modbus协议,下层为TCP协议,它规定了网络互联节点间的请求/应答的通信方式。帧格式必须严格遵守协议所规定的ADU(ApplicationDataUnit)格式,才能在以太网上实现数据的传输。图3所示即为Modbus/TCP的数据帧格式其。

MBAP报文头(ModbusApplicationProtocolHeader)是TCP/IP使用的专用报文头,用来识别Modbus的应用数据单元。MBAP共有7个字节,其具体组成及含义如表2所列。

基于RTU油井远程测控系统的数据采集与传输层软件设计

图3  Modbus/TCP数据帧格式

表2  MBAP报文头


长度
描述
事务元标识符
(TransactionID)
2字节
Modbus请求/响应事务处理的标识符
协议标识符
(ProtocolID)
2字节
0=Modbus协议
长度(Length)
2字节
以下(包括了单元标识域和数据域)的字节数量
单元标识符
(UnitID)
1字节
串行链路或其他总线上连接的远程从站识别码

国际互联网编号分配管理机构IANA(InternetAssignedNumbersAuthority)专门为其赋予了一个TCP端口号502端口,利用TCP发送所有的Modbus/TCPADU。

3.1.3  Modbus/TCP与ModbusRTU数据帧的区别

Modbus/TCP虽然包括了从站地址、功能码和传输的数据,但是没有校验控制码,这是因为Modbus/TCP校验功能已经在下面的四层如TCP/IP协议和链路层的校验机制得到了保证。

3.2  数据采集与传输层系统软件设计

油井远程测控系统的数据采集与传输层主要完成的功能:传感器数据的采集、传输和对继电器的控制。图1中提到了两种常见的工作方式。在井场1中存在RTU主站和从站:主站主要负责对各从站进行轮询、数据打包和向上位机发送数据,从站主要负责数据的采集、继电器的控制和轮询命令的响应,主从站之间的通信使用的是Modbus/RTU。在井场2中只存在一个RTU,主要完成数据的采集、继电器的控制和向上位机发送数据,通信使用的是Modbus/TCP。在数据采集与传输层的工作过程中,考虑到系统的兼容性,对RTU软件设计提出了可配置的要求,不需要重新下载程序,只需要使用系统配置软件就可选择不同的工作方式和通信方式,这就保证了系统的可操作性和兼容性,系统的适应性大大加强。

在软件开发过程中,考虑到串行通信速度较慢的特点,采用多线程技术,故引入实时操作系统Mc/os_II,将Modbus/RTU通信、Modbus/TCP通信等放在单独的线程中进行,而数据采集和控制等则采用另外的线程实现。

3.2.1  MC/OS_II的移植

MC/OS_II是可移植、可剪裁的抢占式实时多任务操作系统内核,适用于工业控制中的实时监控。本系统成功地将实时操作系统MC/OS_II移植到S3C2440A微处理器上,并实现了Modbus通信协议。

MC/OS_II可以管理64个任务,具有信号量、互斥信号量、消息队列、任务管理、时间管理和内存块管理等系统功能。MC/OS_II的移植主要包括三部分代码:mc/os_ii核心代码財c/os_n配置代码叩C/OS_11移植代码。其中MC/OS_II移植代码包括1个汇编文件、1个C程序文件和1个头文件。这部分代码与微处理器相关,是移植的关键"O3.2.2Modbus通信的实现

RTU与上位机使用Modbus/TCP进行以太网通信时,需不断接收上位机发送的査询命令,处于服务器(从站)状态。RTU在使用Modbus/RTU进行串口通信时,需单独完成主从站功能。在实际应用中,不存在Modbus/TCP和Modbus/RTU的从站并存在同一RTU的情况,因而在程序编写过程中,Modbus/TCP和Modbus/RTU的从站使用同一个Modbus从站库,但对其帧头的处理略有不同。以下分别讲述Modbus/TCP服务器(从站)在TCP/IP协议栈上的实现以及Modbus/RTU主站在串口通信上的实现。

(1)Modbus/TCP通信协议实现

由于操作系统MC/OS_II本身没有TCP/IP协议栈,故先移植嵌入TCP/IP协议栈,再编写Modbus/TCP服务器(从站)程序。在MC/OS_II下嵌入了TCP/IP协议栈后就监听TCP502端口的连接请求,只有在与客户机建立了连接之后才能进行数据处理。服务器端在收到客户机的请求之后,会确认和客户机的连接,同时接收并分析客户机的请求报文。如果MBAP报文头正确,则读完所有的报文,只有协议类型值为0x00时才对请求帧进行下一步操作,否则直接丢弃报文。接着分析PDU中的功能代码,不同的功能对参数要求也不同,最后根据数据域中的参数规定,执行相应的操作。若有错误出现,直接丢弃报文,仍继续处理PDU的数据显得不必要,影响实时性。根据对客户端请求报文的分析处理,有两种响应结果,一种是正常的响应报文,另一种是异常响应报文,即返回的是错误信息。其Modbus/TCP的从站通信流程如图4所示。

基于RTU油井远程测控系统的数据采集与传输层软件设计

图4  Modbus/TCP服务器(从站)设计流程图

(2)Modbus/RTU通信协议实现

Modbus主站需要处理发送请求帧、等待应答、处理应答、处理差错和等待转换延时等事件。其主站设计流程如图5所示。

基于RTU油井远程测控系统的数据采集与传输层软件设计

图5  Modbus/RTU主站设计流程图

Modbus/RTU报文帧是否完整和帧与帧之间的区分可以通过空闲间隔来实现,但这需要使用定时器完成1.5个字符和3.5个字符的定时,并在定时到后,进入接收处理函数,然后实现ADU数据到PDU数据的处理。

3.2.3  系统软件的实现

系统上电后,首先进行初始化操作,主要包括设置串口、定时器等内容,并读取EEPROM中的配置信息,对RTU进行配置,包括主从工作模式选择、IP地址设置、轮询的通信方式选择、传感器的开关状态、继电器输出状态等。若处于主站状态,还可以获取从站配置信息并配置从站,配置成功后,主站开始对各从站进行扫描,并对从站报文进行处理;每扫描完一个从站,主站就对轮询到的数据进行存储;在扫描从站的同时,如果主站传感器和外部继电器处于开状态,会同时采集模拟通道和数字通道的数据并控制外部继电器,采集到的数据存于相应寄存器中,等待上位机请求命令,按照Modbus协议将相应数据打包,并上传到上位机。若处于从站,采集模拟通道和数字通道的数据并控制外部继电器,采集到的数据存于相应寄存器中,并等待RTU主站轮询命令,当轮询到该从站时,按Modbus协议打包数据并发送到RTU主站。不管该RTU是主站还是从站,其TCP/IP的服务器程序一直等待系统配置软件的配置信息,当收到配置信息后,将数据存入EEPROM并复位系统程序,整个系统设计流程图如图6所示。

基于RTU油井远程测控系统的数据采集与传输层软件设计

图6  系统设计流程图

从图6中可以同时看到Modbus/RTU和Modbus/TCP的从站处理函数,在实际应用中,RTU处于Modbus/RTU主站时,其Modbus/RTU从站的处理任务不运行,Modbus/TCP从站的处理任务运行,该状态下RTU可用于图1中井场1的RTU主站和井场2的RTU两种情况;处于Modbus/RTU从站时,该状态下RTU可用于图1中井场1的从站情况,以太网服务器任务只等待配置信息。

4  测试

本系统的测试釆用了第三方的Modbus测试工具ModbusPollV4.3.3ModbusSlaveV4.3.1和实验室自主开发的配置软件。

4.1  轮询测试

利用系统配置软件的界面如图7所示,设置一个RTU主站和两个RTU从站,在一台PC机上运行ModbusPoll程序,模拟Modbus/TCP客户机,通过以太网与RTU主站相连,RTU主从站之间通过无线ZigBee模块(或RS485模块)相连。串行通信的波特率设置为38400b/s,无校验位,停止位为1位。

基于RTU油井远程测控系统的数据采集与传输层软件设计基于RTU油井远程测控系统的数据采集与传输层软件设计

图7  系统配置软件界面

PC端的Modbus/TCP客户机可向RTU主站发送命令,并读取存于RTU主站输入寄存器的从站数据。当从站的数字输入端接高电平(24V)时,从ModbusPoll的对应地址可读取到1,图8所示是Modbus/TCP客户机接收到的轮询数据,其中地址500-507为从站1中8通道数字输入端对应的状态值;地址508〜515为从站2中8通道数字输入端对应的状态值。经多次测量,均正确无误。

基于RTU油井远程测控系统的数据采集与传输层软件设计

图8  Modbus/TCP客户机接收到的轮询数据

4.2  控制测试

PC端模拟的Modbus/TCP客户机向RTU的保持寄存器写入数据,RTU会将对应寄存器的数据输出到对应的数字输出端口,例如地址100对应数字输出端口0,当对地址100置1时,对应指示灯亮,输出高电平。

4.3  数据采集测试

RTU模拟输入端0接一定频率的正弦波,数字输入端接高电平信号,利用ModbusPoll査询RTU模拟输入端与数字输入端的数据。

图9所示为Modbus/TCP客户机所接收到的采集数据。

基于RTU油井远程测控系统的数据采集与传输层软件设计

图9  Modbus/TCP客户机接收到的采集数据

RTU采集到数字输入端的脉冲值以及开关状态,地址0〜7对应相应通道的脉冲值,地址8〜15对应相应通道的开关状态值;地址19为RTU板上的温度传感器的值,当前RTU的温度是24°C;地址20〜49为模拟通道0采集到的正弦波信号,之后为其他通道采集到的AD值,每个通道的采样点数和频率可调。

5  结语

在油井远程测控系统数据采集与传输层系统软件设计中,由于采用了MC/OS_II的操作系统平台,可实现Modbus/RTU和Modbus/TCP通信,还可采集各种数字、模拟传感器的数据,并能对外部继电器进行控制,保障了本系统能适用于各种工作环境。此外,还可以根据实际的工作环境,利用系统配置软件进行合理的配置,保证了系统数据采集与传输层工作方式的多样性。经过一段时间的运行,本系统工作稳定、可靠。

20210830_612c639a7e188__基于RTU油井远程测控系统的数据采集与

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭