CN107465620B - 一种通用数据路由器及其通信方法 - Google Patents
一种通用数据路由器及其通信方法 Download PDFInfo
- Publication number
- CN107465620B CN107465620B CN201710653711.2A CN201710653711A CN107465620B CN 107465620 B CN107465620 B CN 107465620B CN 201710653711 A CN201710653711 A CN 201710653711A CN 107465620 B CN107465620 B CN 107465620B
- Authority
- CN
- China
- Prior art keywords
- communication
- data router
- node
- data
- thread
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L45/00—Routing or path finding of packets in data switching networks
- H04L45/02—Topology update or discovery
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/50—Testing arrangements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/12—Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Health & Medical Sciences (AREA)
- Computing Systems (AREA)
- General Health & Medical Sciences (AREA)
- Medical Informatics (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明提供一种通用数据路由器及其通信方法,通用数据路由器中配置有通信驱动动态库和多个节点,并采用线程池的模式来动态检测和管理通信链路;所述通信驱动动态库在被通信被激活的情况下,供数据路由器自动加载通信驱动;每个所述节点对应一个通信设备,每个所述节点是利用组态元件AI、AO作为与通信设备进行数据交互的接口;且每个节点都配置一个计算引擎,用于运行用户利用组态形式所编辑的通信逻辑,并将运行所生成的结果写入该节点对应的共享内存中,供其它节点调用。
Description
技术领域
本发明涉及一种通用数据路由器及其通信方法,属于工业自动化控制技术领域。
背景技术
随着信息科学技术快速发展,传感器技术及物联网技术也得到了飞速的进步。在现在设备联控、智能工厂的要求下,PLC、上位计算机、传感器和其他智能设备之间的信息交互变得尤为重要。当今各国都尝试建设自己的物联网,通过各种信息传感设备,实时采集任何需要监控、连接、互动的物体或过程等各种需要的信息,与互联网结合形成的一个巨大网络。其目的是实现物与物、物与人,所有的物品与网络的连接,方便识别、管理和控制。
然而,当前不同厂商所生产的信息传感设备所采用的通信协议通常是不相同的,通信协议种类的繁多,也导致了通信驱动的多样化。同时绝大多数的通信驱动都是处于黑盒状态,用户针对单个硬件设备重新开发通信驱动存在较大难度,工作量繁重。这就为用户同时采集多个异构设备间的数据信息带来极大不便,为物联网的推广造成了巨大阻力。
本申请就是基于现有技术的不足,提供一种能同时实现对异构设备进行通信的方法,以轻松实现产品信息互通,信息传递不再受限。通过以数据路由器为通信桥梁,实现不同通信协议的异构设备间的互联,促进物联网的发展。
发明内容
本发明要解决的技术问题,在于提供一种通用数据路由器及其通信方法,通过元件组态的形式,实现对不同的通信设备、协议的通信能力,在数据路由器各个节点之间共享、引用。
本发明的数据路由器是这样实现的:一种通用数据路由器,所述数据路由器中配置有通信驱动动态库和多个节点;
所述通信驱动动态库在被通信被激活的情况下,供数据路由器自动加载通信驱动;
每个所述节点对应一个通信设备,每个所述节点是利用组态元件AI、AO作为与通信设备进行数据交互的接口;且每个节点都配置一个计算引擎,用于运行用户利用组态形式所编辑的通信逻辑,并将运行所生成的结果写入该节点对应的共享内存中,供其它节点调用。
进一步的,所述通信逻辑中包含:
通信激活元件,用于向通信线程发送指令,确认是否开始工作;
通信数据类型元件,用于确定通信的数据类型,线程将根据该数据类型调用相应的通信驱动;以及
通信条数配置元件,用于定义需收发的字段位于通信协议的具体位置,从而实现对指定数据的读写。
本发明方法是这样实现的:一种通用数据路由器的通信方法,采用本发明上述的通用数据路由器;并采用线程池的模式来动态检测和管理通信链路。
进一步的,所述动态检测和管理通信链路具体是:每次在所述计算引擎启动完成之后,所述线程池检测所启动的计算引擎的数量,从而得到对应节点的数量,进而启动相应数量的线程,使一个线程为一个节点服务。
进一步的,所述线程池需要调用的接口有多引擎内存区接口和通信驱动接口,且该两个接口保存在所述驱动动态库。
进一步的,本发明通信方法的具体过程是:
通信前所述数据路由器先启动N个节点,同时创建N个共享内存;
然后在相应的线程池中激活N个线程,并且进入睡眠模式,等待组态软件的组态数据,下载至各个节点;
线程池内睡眠线程接收到通信任务时,将激活通信驱动动态库并且调用相应的通信驱动,进而开始通信。
本发明具有如下优点:本发明提供的通用数据路由器把通信过程需要的数据与产生的数据,通过元件组态的形式,进行参数配置、数据拆分、数据拼接,以达到实现对不同的通信设备、协议的通信能力,在数据引擎各个节点之间共享、引用。
附图说明
下面参照附图结合实施例对本发明作进一步的说明。
图1为本发明数据路由器软件配置架构框图。
图2为本发明通信方法的流程示意图。
具体实施方式
本发明的数据路由器中配置有通信驱动动态库和多个节点;
所述通信驱动动态库在被通信被激活的情况下,供数据路由器自动加载通信驱动;
每个所述节点对应一个通信设备,每个所述节点是利用组态元件AI、AO作为与通信设备进行数据交互的接口;通过组态元件AI将通信设备的信息存入对应节点;通过组态元件AO将数据写入通信设备;
且每个节点都配置一个计算引擎,用于运行用户利用组态形式所编辑的通信逻辑,并将运行所生成的结果写入该节点对应的共享内存中,供其它节点调用。
所述通信逻辑中包含:
通信激活元件,用于向通信线程发送指令,确认是否开始工作;
通信数据类型元件,用于确定通信的数据类型,线程将根据该数据类型调用相应的通信驱动;以及
通信条数配置元件,用于定义需收发的字段位于通信协议的具体位置,从而实现对指定数据的读写。
基于本发明上述的通用数据路由器,本发明的通信方法采用线程池的模式来动态检测和管理通信链路。具体是:每次在所述计算引擎启动完成之后,所述线程池检测所启动的计算引擎的数量,从而得到对应节点的数量,进而启动相应数量的线程,使一个线程为一个节点服务。
所述线程池需要调用的接口有多引擎内存区接口和通信驱动接口,且该两个接口保存在所述驱动动态库,即以动态库的形式,存放在usr/lib,这样在修改驱动程序的时候,只需要修改驱动部分,就能重新安装至硬件设备。
从而使本发明的通用数据路由器形成如图1所示的软件结构,其包括三个部分,分别为Linux多引擎,共享内存以及线程池。
如图2所示,本发明通信方法的具体过程是:
通信前所述数据路由器先启动N个节点,同时创建N个共享内存;
然后在相应的线程池中激活N个线程,并且进入睡眠模式,等待组态软件的组态数据,下载至各个节点;
线程池内睡眠线程接收到通信任务时,将激活通信驱动动态库并且调用相应的通信驱动,然后设置通信参数,读取通信条数后即可开始通信。
虽然以上描述了本发明的具体实施方式,但是熟悉本技术领域的技术人员应当理解,我们所描述的具体的实施例只是说明性的,而不是用于对本发明的范围的限定,熟悉本领域的技术人员在依照本发明的精神所作的等效的修饰以及变化,都应当涵盖在本发明的权利要求所保护的范围内。
Claims (5)
1.一种通用数据路由器,其特征在于:所述数据路由器中配置有通信驱动动态库和多个节点;
所述通信驱动动态库在被通信被激活的情况下,供数据路由器自动加载通信驱动;
每个所述节点对应一个通信设备,每个所述节点是利用组态元件AI、AO作为与通信设备进行数据交互的接口;且每个节点都配置一个计算引擎,用于运行用户利用组态形式所编辑的通信逻辑,并将运行所生成的结果写入该节点对应的共享内存中,供其它节点调用;所述通信逻辑中包含:
通信激活元件,用于向通信线程发送指令,确认是否开始工作;
通信数据类型元件,用于确定通信的数据类型,线程将根据该数据类型调用相应的通信驱动;以及
通信条数配置元件,用于定义需收发的字段位于通信协议的具体位置,从而实现对指定数据的读写。
2.一种通用数据路由器的通信方法,其特征在于:采用权利要求1所述的通用数据路由器;并采用线程池的模式来动态检测和管理通信链路。
3.根据权利要求2所述的一种通用数据路由器的通信方法,其特征在于:所述动态检测和管理通信链路具体是:每次在所述计算引擎启动完成之后,所述线程池检测所启动的计算引擎的数量,从而得到对应节点的数量,进而启动相应数量的线程,使一个线程为一个节点服务。
4.根据权利要求2所述的一种通用数据路由器的通信方法,其特征在于:所述线程池需要调用的接口有多引擎内存区接口和通信驱动接口,且该两个接口保存在所述驱动动态库。
5.根据权利要求2所述的一种通用数据路由器的通信方法,其特征在于:具体过程是:
通信前所述数据路由器先启动N个节点,同时创建N个共享内存;
然后在相应的线程池中激活N个线程,并且进入睡眠模式,等待组态软件的组态数据,下载至各个节点;
线程池内睡眠线程接收到通信任务时,将激活通信驱动动态库并且调用相应的通信驱动,进而开始通信。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710653711.2A CN107465620B (zh) | 2017-08-03 | 2017-08-03 | 一种通用数据路由器及其通信方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710653711.2A CN107465620B (zh) | 2017-08-03 | 2017-08-03 | 一种通用数据路由器及其通信方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107465620A CN107465620A (zh) | 2017-12-12 |
CN107465620B true CN107465620B (zh) | 2020-07-10 |
Family
ID=60548261
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710653711.2A Active CN107465620B (zh) | 2017-08-03 | 2017-08-03 | 一种通用数据路由器及其通信方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107465620B (zh) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110602262A (zh) * | 2018-06-13 | 2019-12-20 | 网宿科技股份有限公司 | 路由器及其处理数据报文的方法 |
CN110018916B (zh) * | 2019-04-10 | 2022-10-21 | 福州大学 | 一种通信任务可组态功能的实现方法 |
CN111010346B (zh) * | 2019-12-23 | 2021-10-19 | 深信服科技股份有限公司 | 基于动态路由的报文处理方法、设备、存储介质及装置 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5926775A (en) * | 1997-10-08 | 1999-07-20 | National Instruments Corporation | Mini driver software architecture for a data acquisition system |
CN1604066A (zh) * | 2003-09-29 | 2005-04-06 | 中国科学院沈阳自动化研究所 | 嵌入式网络化远程输入输出系统 |
CN101150468A (zh) * | 2007-10-29 | 2008-03-26 | 上海和伟科技发展有限公司 | 一种数据采集与电子记录系统及其数据采集与记录方法 |
CN102801658A (zh) * | 2011-05-23 | 2012-11-28 | 镇江金钛软件有限公司 | 一种可组态物联网接入网关 |
CN105939253A (zh) * | 2016-04-14 | 2016-09-14 | 江汉大学 | 一种工业无线网关装置及其协议转换方法 |
CN106647412A (zh) * | 2017-01-17 | 2017-05-10 | 爱普(福建)科技有限公司 | 一种基于组态元件的分布式控制器之间的数据共享方法 |
-
2017
- 2017-08-03 CN CN201710653711.2A patent/CN107465620B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5926775A (en) * | 1997-10-08 | 1999-07-20 | National Instruments Corporation | Mini driver software architecture for a data acquisition system |
CN1604066A (zh) * | 2003-09-29 | 2005-04-06 | 中国科学院沈阳自动化研究所 | 嵌入式网络化远程输入输出系统 |
CN101150468A (zh) * | 2007-10-29 | 2008-03-26 | 上海和伟科技发展有限公司 | 一种数据采集与电子记录系统及其数据采集与记录方法 |
CN102801658A (zh) * | 2011-05-23 | 2012-11-28 | 镇江金钛软件有限公司 | 一种可组态物联网接入网关 |
CN105939253A (zh) * | 2016-04-14 | 2016-09-14 | 江汉大学 | 一种工业无线网关装置及其协议转换方法 |
CN106647412A (zh) * | 2017-01-17 | 2017-05-10 | 爱普(福建)科技有限公司 | 一种基于组态元件的分布式控制器之间的数据共享方法 |
Also Published As
Publication number | Publication date |
---|---|
CN107465620A (zh) | 2017-12-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107465620B (zh) | 一种通用数据路由器及其通信方法 | |
CN112363775B (zh) | 动态修改微服务配置信息的方法及系统、存储介质 | |
CN111966465B (zh) | 一种实时修改宿主机配置参数的方法、系统、设备及介质 | |
EP3489776B1 (en) | Control device, control method, and program | |
US9824229B2 (en) | Controller with enhanced reliability | |
CN111641669A (zh) | 以网络为中心的进程控制系统中的动态负载平衡 | |
CN106506278A (zh) | 一种服务可用性监控方法及装置 | |
CN112243033B (zh) | 获取内存信息的方法、装置、设备及计算机可读存储介质 | |
JP3739897B2 (ja) | プログラマブルコントローラ | |
CN115878213A (zh) | 物联网设备驱动的动态加载方法 | |
CN112506654B (zh) | 一种工业机器人分布式协同调试方法及系统 | |
CN113867271A (zh) | 生产系统、上级控制装置、控制装置、通信方法以及存储介质 | |
KR101102930B1 (ko) | 로봇용 소프트웨어 컴포넌트 장치 및 이를 이용한 쓰레드 처리 방법 | |
CN110007653B (zh) | 一种焊接控制系统的配置方法、装置、设备及存储介质 | |
US20210405597A1 (en) | Engineering device, engineering method, and information storage medium | |
CN112363707A (zh) | 一种基于java反射技术的控制层通用调度方法 | |
CN114303107A (zh) | 用于在具有opc ua的控制程序中同步地调用功能模块的方法和工业控制器 | |
CN110618914A (zh) | 一种面向分布式系统集群的监控方法、装置及系统 | |
CN114900511B (zh) | 工业机器人数据同步采集加载中间件装置及方法 | |
US20230215226A1 (en) | Method for vehicle diagnostics, diagnostic connector, and diagnostic device | |
CN114666241B (zh) | 一种识别工控资产信息的方法及装置 | |
CN113050554B (zh) | 人机交互多协议通讯方法及介质 | |
Kimm et al. | Implementation of networked robot control system over controller area network | |
CN106802582B (zh) | 一种用于机器人的传感器数据调用方法以及机器人 | |
JP3350699B2 (ja) | プログラマブルコントローラ |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |