首页> 中国专利> 一种基于OPC-UA服务平台的工业无线网络服务适配方法

一种基于OPC-UA服务平台的工业无线网络服务适配方法

摘要

本发明涉及一种基于OPC‑UA服务平台的工业无线网络服务适配方法,首先初始化运行参数并将运行参数保存到共享内存,根据共享内存中各个运行参数初始化各通信端口以及协议工作状态;通信端口和协议在工作时随共享内存中运行参数的改变而重新配置自己工作状态;共享内存中的运行参数通过OPC‑UA监听方法进行管理。本发明提高生产过程的智能化程度,对生产系统进行细粒度监控和整体优化,提供多态网络架构中多种传输技术的融合能力,并且提高设备间的通信能力。

著录项

  • 公开/公告号CN108076026A

    专利类型发明专利

  • 公开/公告日2018-05-25

    原文格式PDF

  • 申请/专利权人 中国科学院沈阳自动化研究所;

    申请/专利号CN201611027010.X

  • 申请日2016-11-15

  • 分类号H04L29/06(20060101);H04L29/08(20060101);H04L12/24(20060101);

  • 代理机构21002 沈阳科苑专利商标代理有限公司;

  • 代理人李巨智

  • 地址 110016 辽宁省沈阳市东陵区南塔街114号

  • 入库时间 2023-06-19 05:24:22

法律信息

  • 法律状态公告日

    法律状态信息

    法律状态

  • 2020-04-07

    授权

    授权

  • 2018-06-19

    实质审查的生效 IPC(主分类):H04L29/06 申请日:20161115

    实质审查的生效

  • 2018-05-25

    公开

    公开

说明书

技术领域

本发明涉及工业控制中无线及有线通信领域,具体地说是一种基于OPC-UA服务平台的工业无线网络服务适配方法。

背景技术

目前,在冶金、石化等生产系统中,人工抄表的现象仍然大量存在。这表明我国流程工业生产过程智能化程度仍然很低,在很多复杂、多环节生产系统中,未能达到细粒度控制。为达到复杂生产系统的细粒度控制以及多环节的协同优化的目的,就要实现多环节生产参数统一采集与控制,各生产过程设备统一组网。可是当前工业生产环境的现状是,现场设备间通信协议不统一,老设备更没有统一的组网接口。将现场仪表全部更换成为具备统一组网接口的新表需要大量人力物力,显然并不现实。因此急需一种支持多种协议通信接口的服务适配仪器,实现将不同工业协议的仪表统一组网的功能。

OPC-UA是OPC基金会发布的最新一代用于工业自动化的数据交换规范,它将以往OPC数据存取(DA)、OPC报警和事件(A&E)以及OPC历史数据存取(HDA)统一成一个具备数据处理、报警和事件、历史数据存取功能的同时具备很强对象描述能力的地址空间。

目前还没有一款集成OPC-UA服务平台的用于工业无线网络适配的设备。没有一种统一有效的,能够对ModbusTCP通信协议、ModbusRTU通信协议、WirelessHART通信协议、工业以太网通信协议、工业RS232通信协议、工业RS485通信协议等主流工业通信协议进行描述和配置,同时提供一种能够将各种通信协议关键数据统一上报协议的方法。

发明内容

针对现有技术的不足,本发明提供一种基于OPC-UA服务平台的工业无线网络服务适配方法,支持ModbusTCP、ModbusRTU、WirelessHART、工业以太网TCP、工业以太网UDP、RS232数据透明传输、RS485数据透明传输等多种通信协议,并通过OPC-UA技术对各种通信协议提供统一的解析、描述与表现,很好地解决了多态网络架构下多协议设备共存的问题与不同工业协议导致的信息孤岛问题。

本发明为实现上述目的所采用的技术方案是:

一种基于OPC-UA服务平台的工业无线网络服务适配方法,首先初始化运行参数并将运行参数保存到共享内存,根据共享内存中各个运行参数初始化各通信端口以及协议工作状态;

通信端口和协议在工作时随共享内存中运行参数的改变而重新配置自己工作状态;

共享内存中的运行参数通过OPC-UA监听方法进行管理。

所述通信端口和协议在工作时会随共享内存信息的改变而重新配置自己工作状态包括以下过程:

步骤1:判断是否有通信端口接收到报文,如果是,先按照共享内存所配置的协议解析报文,并更新共享内存,读取共享内存区中各个协议和端口运行参数;否则直接读取共享内存区中各个通信端口和协议的运行参数;

步骤2:判断运行参数是否发生变化,如果是,则更改通信端口和协议的运行状态,按照协议上传和下发报文,并返回步骤1;否则直接按照协议上传和下发报文,并返回步骤1。

所述OPC-UA监听方法为:

步骤1:将各个运行参数配置到共享内存,并根据运行参数对OPC-UA服务平台初始化,开启OPC-UA服务器;

步骤2:判断客户端是否读取节点,如果是,读取共享内存中各个通信端口或协议的运行参数,返回给客户端,并继续判断客户端是否对节点值进行修改;否则直接判断客户端是否对节点值进行修改;

步骤3:如果客户端对节点值进行修改,则对该节点值对应的运行参数进行修改,将修改后的运行参数写入共享内存,并继续监听。

所述对OPC-UA服务平台初始化包括以下过程:

步骤1:配置服务器的基本信息,并生成安全证书;

步骤2:调用函数生成各个通信端口控制的对象,并配置对象的属性信息;

步骤3:建立从属于对象的子节点,配置各个子节点的属性信息和读写方法,并将子节点的父节点引用指向从属对象,完成子集生成。

所述基本信息包括:制造商信息、应用名称信息以及统一资源标识符信息。

所述通信端口包括:OPC-UA服务器的以太网端口、工业通信以太网端口、RS232端口、RS485端口和无线通信模块端口。

所述协议包括:ModbusTCP通信协议、ModbusRTU通信协议、WirelessHART通信协议、工业以太网透明传输协议、RS232透明传输协议、RS485透明传输协议以及适配器数据统一上报协议。

所述适配器数据统一上报协议为:

如果运行参数“Opened”为真,则协议开启,协议对从“ReceiveProtocol”所代表的协议接收到的报文进行解析;否则不开启协议;

判断“IfCmd”是否为真,如果是,协议对接收到的报文进行过滤;否则不进行报文过滤;

如果接收报文的运行参数“CmdPosition”对应的字节等于“CmdMask”,则表示过滤通过并进行后续判断;否则过滤不通过且丢弃该报文;

判断“Capture”是否为真,如果是,在接收报文的“DataPosition”位置抓取长度为“DataLength”的数据,将该数据与用户自定义的“UserMark”按照适配器数据统一上报协议格式一起上传;否则将整个报文上传。

所述适配器数据统一上报协议格式包括:“Opened”、“DataPosition”、“DataLength”、“ReceiveProtocol”、“TransmissionPeriod”、“UserMark”、“ReceiveProtocol”、“IfCmd”、“CmdPosition”、“CmdMask”和“Capture”。

所述适配器数据统一上报协议格式包含的字段从报文开始依次为“DeviceID”、“ReceiveProtocol”、“数据地址”、“IfCmd”、“CmdMask”、“UserMark”、“DataLength”、“数据值”;

“DeviceID”长度为4个字节,为系统的设备唯一标识号码;

“ReceiveProtocol”长度为1个字节,用来表示通信协议获取源,其中1代表“ModbusTCP”;2代表“ModbusRTU”;3代表“WirelessHART”;4代表“TransEthernet”;5代表“TransRS232”;6代表“TransRS485”;“Address”长度为5个字节,代表数据来自于哪个地址,当数据来自于“ModbusTCP”或者“ModbusRTU”时,地址前两个字节代表设备唯一标识符,后两个字节代表Modbus协议线圈或者寄存器地址,当数据来自于WirelessHART协议时,5个字节全部代表设备的长地址,在透明传输模式时,此字段没有意义并全为0;“IfCmd”长度为1个字节,代表协议是否进行了报文过滤;“CmdMask”长度为1个字节,是报文过滤字节;“UserMask”长度为1个字节,是用户自定义的标识;“DataLength”长度为1个字节,表示需要协议从接收报文截取的数据长度;“Value”长度为“DataLength”的值,是协议所截取的数据。

本发明具有以下有益效果及优点:

1.本发明包含多种工业通信接口:工业以太网接口、工业RS232接口、工业RS485接口。并且支持多种工业通信协议:ModbusTCP通信协议、ModbusRTU通信协议、WirelessHART通信协议、工业以太网数据透明传输通信协议、RS232数据透明传输通信协议、RS485数据透明传输通信协议。具有很强的工业系统兼容能力;

2.本发明系统内部具有OPC-UA服务器,对OPC-UA技术的使用增强了对各个通信协议的描述以及配置能力。同时方便管理人员对系统的管理,管理人员只需下载OPC-UA通用客户端就可以对该服务适配系统进行配置与监控;

3.本发明提供一种适配器数据统一上报协议,具有对不同协议数据统一描述以和向上发送的能力,促进不同协议间融合。

附图说明

图1是本发明的方法流程图;

图2是本发明的OPC-UA服务器生成各个协议模块以及端口配置模块对象的流程图;

图3是本发明的适配器数据统一上报协议格式图。

具体实施方式

下面结合附图及实施例对本发明做进一步的详细说明。

如图1所示为本发明的方法流程图。

一种基于OPC-UA服务平台的工业无线网络服务适配方法,其内部运行有Linux操作系统,并基于Linux操作系统提供功能服务;具备一个作为OPC-UA服务器的以太网端口,可以通过OPC-UA客户端对其进行读取与配置;除了OPC-UA以太网端口外,还具备一个工业以太网端口用于与工业以太网设备互联;具备一个RS232端口,用于与RS232设备通信;具备一个RS485端口,用于与RS485设备通信;具备一个无线通信模块端口用于与2.4G无线通信模块互联。

还包括一种数据统一上报协议,用于不同协议数据的统一解析及上报。

还包括工业通信以太网通信端口,支持ModbusTCP协议,工业以太网TCP协议以及工业以太网UDP协议。

还包括工业RS232端口,支持RS232数据透明传输协议。

还包括工业RS485端口,支持ModbusRTU协议与RS485数据透明传输协议。

还包括一个2.4G无线通信模块端口,用于无线数据通信,同时支持WirelessHART通信协议。

还包括一个OPC-UA服务器,通过OPC-UA服务器对上述各个协议的的应用数据提供统一描述和解析,同时对多功能工业网络服务适配系统的运行参数进行查看与配置。

系统运行的配置信息按照格式保存在“AdapterConfig”文件中。通过调用子线程的方法分别控制工业以太网端口、RS232端口、RS485端口、无线通信模块端口的工作。系统通过OPC-UA服务器将各个协议信息向客户端暴露,OPC-UA服务器同时提供对系统的配置功能。OPC-UA服务器采用共享内存的方式与各个端口进行交互。通过配置对象“AdapterUnitProtocol”,系统可以将各个协议数据解析为统一格式并且使用被配置的端口向外发送。

如图2所示为本发明OPC-UA服务器生成各个协议模块以及端口配置模块对象的流程图。其开发工作基于open62541.org网站所提供的“open62541”开源软件开发包。服务器首先配置“制造商”、“应用名称”、“统一资源标识符”等服务器基本信息。然后生成“server_cert.der”安全证书。OPC-UA服务器以对象的方式描述每个通信协议信息以及对每个通信端口配置信息,并生成对应的对象,包括:“ModbusTCP”、“ModbusRTU”、“WirelessHART”、“TransEthernet”、“TransRS232”、“TransRS485”、“EthernetConfig”、“RS232Config”、“RS485Config”、“WIAConfig”、“AdapterUnitProtocol_1”-“AdapterUnitProtocol_5”。生成这些对象的过程为:首先配置它们的“NodeID”、“description”、“displayName”、“accesslevel”等属性,配置这些对象要调用的读写方法。然后分别以类似的方式配置从属于这些对象的子节点的属性信息及读写方法。这些子节点用于配置和监视各个协议及端口运行状态。并且将这些子节点的父节点引用指向各个对象。各个对象所包含的子节点信息如下各表所示,其中表1为“ModbusTCP”对象子节点信息,表2为“ModbusRTU”对象子节点信息,表3为“WirelessHART”对象子节点信息,表4为“TransEthernet”对象子节点信息,“TransRS232”和“TransRS485”对象拥有一样的子节点并且如表5所示,表6列出了“EthernetConfig”对象的子节点信息,“RS232Config”、“RS485Config”和“WIAConfig”拥有一样的子节点,如表7所示:

数据类型子节点名称BooleanOpenedBooleanHexadecimalInt32UploadTimeArray/Boolean1-9_PeriodicallyArray/UInt161-9_DeviceIDArray/UInt161-9_AddressArray/UInt161-9_ValueArray/Byte1-9_VariableTypeArray/Boolean1-9_R/W

表1

数据类型子节点名称BooleanOpenedBooleanHexadecimalInt32UploadTimeArray/Boolean1-9_PeriodicallyArray/UInt161-9_DeviceIDArray/UInt161-9_AddressArray/UInt161-9_ValueArray/Byte1-9_VariableTypeArray/Boolean1-9_R/W

表2

表3

数据类型子节点名称BooleanOpenedBooleanHexadecimalBooleanTCP/UDPUInt32TransmissionPeriodStringCommandToSendStringReceivedMessage

表4

数据类型子节点名称BooleanHexadecimalUInt32TransmissionPeriodStringCommandToSendStringReceivedMessage

表5

数据类型子节点名称Array/ByteLocalIPAddressArray/ByteRemoteIPAddressUInt16LocalPortNumUInt16RemotePortNumByteTCPServer/TCPClient/TCPOffBooleanUDPOff/UDPOn

表6

数据类型子节点名称UInt32BandrateByteParityByteStopbitsByteFrameLength

表7

如图3所示为本发明适配器数据统一上报协议的报文格式。系统提供了一种将各个协议数据统一描述并上传的功能,对象“AdapterUnitProtocol_1”到对象“AdapterUnitProtocol_5”用于对此功能进行描述。这两个对象包含相同的子节点,如表8所示:

数据类型子节点名称BooleanOpenedUInt32TransmissionPeriodByteUserMarkByteReceiveProtocolBooleanIfCmdUInt16CmdPositionByteCmdMaskBooleanCaptureByteReceiveProtocolByteDataLengthUInt16DataPosition

表8

通过配置子节点“Opended”为“true”将该功能打开。布尔值“Capture”用来指示是否从接收报文中截取数据,当开启时,系统会从“ReceiveProtocol”对应协议的接收报文中截取某一字段作为发送数据,被截取数据的长度用“DataLength”子节点表示,截取数据的位置的值为“DataPosition”的值。“IfCmd”、“CmdPosition”和“CmdMask”用来添加数据截取的限定条件,即当满足“IfCmd”为true并且接受报文的“CmdPosition”位置的值为“CmdMask”的时候才进行数据截取。“TransmissionPeriod”用来指定发送间隔,“UserMark”为单字节的用户自定义标识。发送数据时,帧的前4个字节为系统唯一ID号码,第五个字节是“ReceiveProtocol”的值,其中1代表“ModbusTCP”;2代表“ModbusRTU”;3代表“WirelessHART”;4代表“TransEthernet”;5代表“TransRS232”;6代表“TransRS485”。其后“Address”长度为5个字节代表数据来自于哪个地址,当数据来自于“ModbusTCP”或者“ModbusRTU”时,地址前两个字节代表设备唯一标识符,后两个字节代表Modbus协议线圈或者寄存器地址;当数据来自于WirelessHART协议时,5个字节全部代表设备的长地址。在透明传输模式时,此字段没有意义并全为0。最后的“Value”字段为之前获取的数据,其长度取决于“DataLength”。

去获取专利,查看全文>

相似文献

  • 专利
  • 中文文献
  • 外文文献
获取专利

客服邮箱:kefu@zhangqiaokeyan.com

京公网安备:11010802029741号 ICP备案号:京ICP备15016152号-6 六维联合信息科技 (北京) 有限公司©版权所有
  • 客服微信

  • 服务号