CN113179269A - 基于物联网的协议数据解析方法、系统、介质及程序产品 - Google Patents
基于物联网的协议数据解析方法、系统、介质及程序产品 Download PDFInfo
- Publication number
- CN113179269A CN113179269A CN202110464284.XA CN202110464284A CN113179269A CN 113179269 A CN113179269 A CN 113179269A CN 202110464284 A CN202110464284 A CN 202110464284A CN 113179269 A CN113179269 A CN 113179269A
- Authority
- CN
- China
- Prior art keywords
- protocol data
- data analysis
- internet
- things
- service
- 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.)
- Granted
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/22—Parsing or analysis of headers
-
- 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/18—Multiprotocol handlers, e.g. single devices capable of handling multiple protocols
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Health & Medical Sciences (AREA)
- Computing Systems (AREA)
- General Health & Medical Sciences (AREA)
- Medical Informatics (AREA)
- Computer And Data Communications (AREA)
- Communication Control (AREA)
Abstract
本发明公开了一种基于物联网的协议数据解析方法、系统、计算机可读存储介质及计算机程序产品,所述基于物联网的协议数据解析方法包括:当物联网设备向物联网平台发送协议数据时,通过所述物联网平台的设备接入服务接收所述协议数据;从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务,其中,所述协议数据解析服务为可执行程序;将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据;将所述格式化数据返回至所述物联网平台,以供所述物联网平台对所述格式化数据进行处理。本发明提高了物联网协议数据的解析效率,并减少了服务器的资源占用。
Description
技术领域
本发明涉及物联网技术领域,尤其涉及一种基于物联网的协议数据解析方法、系统、计算机可读存储介质及计算机程序产品。
背景技术
随着5G通信技术及物联网技术的迅速发展,物联网设备的应用越来越广泛。而物联网平台作为物联网应用的基础平台,需要提供大量不同协议的物联网设备(例如传感器、网关设备等)的接入和管理能力。具体的,物联网设备可以通过TCP(Transmission ControlProtocol,传输控制协议)、UDP(User Datagram Protocol,用户数据报协议)、MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议)、COAP(ConstrainedApplication Protocol,受限应用协议)、HTTP(HyperText Transfer Protocol,超文本传输协议)等多种不同的协议接入该物联网平台。其中,物理网设备发送的数据包括各种数据格式,例如,数据格式有JSON(JavaScript Object Notation,JS对象简谱)、Modbus(Modbusprotocol,串行通信协议)、私有格式等多种不同的格式。而物联网平台需要将这些不同的数据格式转换成统一格式,即需要进行协议数据的解析处理,以便后续对统一格式的数据进行相应的业务处理(例如存储、分发、分析等处理)。因此,物联网平台需要支持多种协议数据的解析方法,以接收各种不同通信协议的物联网设备发送的数据信息。
首先,参阅申请号为CN201110024051.4的技术方案,其通过图形化的配置方式,只适合一些标准协议或协议数据比较简单的场景,而对于一些私有格式,或者协议复杂的场景,则无法满足要求。
其次,参阅申请号为CN202010761931.9的技术方案,其通过一些动态的脚本语言来解析,由于脚本语言大多为解释型语言(例如JavaScript、Python、PHP等脚本语言),执行效率相对较低,对于大规模的协议解析也会存在性能问题,并且,其需要更多的服务器资源。
最后,虽然基于Java的类动态加载的方式,可以加载开发者提供的协议解析包,但是这种方式会有消耗资源较大或库冲突的问题。具体的,如果在一个Java虚拟机中加载多种协议解析库的实现类,这些解析库如果依赖一些第三方的包,不同的库就可能存在版本冲突的问题,而如果每种协议使用单独的Java虚拟机,则需要更多的内存资源。
综上所述,如何提高物联网协议数据的解析效率,以及如何减少服务器的资源占用,是目前亟需解决的问题。
发明内容
本发明的主要目的在于提供一种基于物联网的协议数据解析方法、系统、计算机可读存储介质及计算机程序产品,旨在提高物联网协议数据的解析效率,并减少服务器的资源占用。
为实现上述目的,本发明提供一种基于物联网的协议数据解析方法,所述基于物联网的协议数据解析方法包括以下步骤:
当物联网设备向物联网平台发送协议数据时,通过所述物联网平台的设备接入服务接收所述协议数据;
从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务,其中,所述协议数据解析服务为可执行程序;
将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据;
将所述格式化数据返回至所述物联网平台,以供所述物联网平台对所述格式化数据进行处理。
可选地,所述从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务的步骤包括:
通过协议数据解析服务管理模块,从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务及通信方式,其中,所述通信方式为所述设备接入服务与所述协议数据解析服务进行通信的方式;
其中,所述将所述协议数据发送至所述协议数据解析服务的步骤包括:
通过所述通信方式,将所述协议数据发送至所述协议数据解析服务。
可选地,所述将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据的步骤之前,还包括:
对所述协议数据解析服务进行实例化,以将所述协议数据解析服务对应的可执行程序从所述协议数据解析服务程序库中拷贝至目标设备,以使所述目标设备执行所述可执行程序;
启动所述可执行程序,以得到对应的协议数据解析服务进程;
其中,所述将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据的步骤包括:
将所述协议数据发送至所述协议数据解析服务进程,以通过所述协议数据解析服务进程对所述协议数据进行解析得到格式化数据。
可选地,所述启动所述可执行程序,以得到对应的协议数据解析服务进程的步骤之后,还包括:
将所述协议数据解析服务进程注册至协议数据解析服务管理模块,以通过所述协议数据解析服务管理模块对所述协议数据解析服务进程进行生命周期管理。
可选地,所述物联网设备支持多种通信协议,所述将所述协议数据发送至所述协议数据解析服务的步骤包括:
若所述协议数据解析服务包括多个,则将所述协议数据按照协议类型进行分类;
将分类后的协议数据分别发送至对应协议类型的协议数据解析服务。
可选地,所述基于物联网的协议数据解析方法还包括:
对所述协议数据解析服务进行多次实例化,得到多个实例;
基于所述多个实例,构建所述协议数据解析服务对应的分布式集群,以通过所述分布式集群对所述协议数据进行解析得到格式化数据。
可选地,所述当物联网设备向物联网平台发送协议数据时,通过所述物联网平台的设备接入服务接收所述协议数据的步骤之前,还包括:
获取协议数据解析代码,其中,所述协议数据解析代码包括单一协议类型的数据解析代码和与物联网平台进行交互的相关代码;
对所述协议数据解析代码进行编译,得到可执行程序;
对所述可执行程序绑定相应的发布信息,并将绑定所述发布信息的可执行程序发布至协议数据解析服务程序库,以供从所述协议数据解析服务程序库中查询协议数据对应的协议数据解析服务。
此外,为实现上述目的,本发明还提供一种基于物联网的协议数据解析系统,所述基于物联网的协议数据解析系统包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的协议数据解析程序,所述协议数据解析程序被所述处理器执行时实现如上所述的基于物联网的协议数据解析方法的步骤。
此外,为实现上述目的,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有协议数据解析程序,所述协议数据解析程序被处理器执行时实现如上所述的基于物联网的协议数据解析方法的步骤。
此外,为实现上述目的,本发明还提供一种计算机程序产品,所述计算机程序产品包括计算机程序,所述计算机程序被处理器执行时实现如上所述的基于物联网的协议数据解析方法的步骤。
本发明提供一种基于物联网的协议数据解析方法、系统、计算机可读存储介质及计算机程序产品,当物联网设备向物联网平台发送协议数据时,通过物联网平台的设备接入服务接收协议数据;从协议数据解析服务程序库中查询协议数据对应的协议数据解析服务,其中,协议数据解析服务为可执行程序;将协议数据发送至协议数据解析服务,以通过协议数据解析服务对协议数据进行解析得到格式化数据;将格式化数据返回至物联网平台,以供物联网平台对格式化数据进行处理。通过上述方式,在对接收到的协议数据进行解析时,可以直接查询对应协议类型的协议数据解析服务,以通过该协议数据解析服务对该协议数据进行解析,并且,该协议数据解析服务为可执行程序,即该可执行程序已经是目标设备上可以直接执行的程序,从而提高了物联网协议数据的解析效率。同时,从协议数据解析服务程序库中查询协议数据对应的协议数据解析服务,以使后续进行解析处理的协议数据解析服务进程只对应一个协议类型数据的解析处理,从而减少每个进程的资源占用,进而较少服务器的资源占用。
附图说明
图1为本发明实施例方案涉及的硬件运行环境的终端结构示意图;
图2为本发明基于物联网的协议数据解析方法第一实施例的流程示意图;
图3为本发明基于物联网的协议数据解析方法第三实施例的流程示意图;
图4为本发明基于物联网的协议数据解析方法第六实施例的流程示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
参照图1,图1为本发明实施例方案涉及的硬件运行环境的终端结构示意图。
本发明实施例终端为基于物联网的协议数据解析设备,该基于物联网的协议数据解析设备可以为PC(personal computer,个人计算机)、微型计算机、笔记本电脑、服务器等具有处理功能的终端设备。
如图1所示,该终端可以包括:处理器1001,例如CPU(Central Processing Unit,中央处理器),通信总线1002,用户接口1003,网络接口1004,存储器1005。其中,通信总线1002用于实现这些组件之间的连接通信。用户接口1003可以包括显示屏(Display)、输入单元比如键盘(Keyboard),可选用户接口1003还可以包括标准的有线接口、无线接口。网络接口1004可选的可以包括标准的有线接口、无线接口(如WI-FI接口)。存储器1005可以是高速RAM存储器,也可以是稳定的存储器(non-volatile memory),例如磁盘存储器。存储器1005可选的还可以是独立于前述处理器1001的存储装置。
本领域技术人员可以理解,图1中示出的终端结构并不构成对终端的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
如图1所示,作为一种计算机存储介质的存储器1005中可以包括操作系统、网络通信模块、用户接口模块以及协议数据解析程序。
在图1所示的终端中,处理器1001可以用于调用存储器1005中存储的协议数据解析程序,并执行以下操作:
当物联网设备向物联网平台发送协议数据时,通过所述物联网平台的设备接入服务接收所述协议数据;
从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务,其中,所述协议数据解析服务为可执行程序;
将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据;
将所述格式化数据返回至所述物联网平台,以供所述物联网平台对所述格式化数据进行处理。
进一步地,处理器1001可以用于调用存储器1005中存储的协议数据解析程序,还执行以下操作:
通过协议数据解析服务管理模块,从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务及通信方式,其中,所述通信方式为所述设备接入服务与所述协议数据解析服务进行通信的方式;
其中,所述将所述协议数据发送至所述协议数据解析服务的步骤包括:
通过所述通信方式,将所述协议数据发送至所述协议数据解析服务。
进一步地,处理器1001可以用于调用存储器1005中存储的协议数据解析程序,还执行以下操作:
对所述协议数据解析服务进行实例化,以将所述协议数据解析服务对应的可执行程序从所述协议数据解析服务程序库中拷贝至目标设备,以使所述目标设备执行所述可执行程序;
启动所述可执行程序,以得到对应的协议数据解析服务进程;
其中,所述将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据的步骤包括:
将所述协议数据发送至所述协议数据解析服务进程,以通过所述协议数据解析服务进程对所述协议数据进行解析得到格式化数据。
进一步地,处理器1001可以用于调用存储器1005中存储的协议数据解析程序,还执行以下操作:
将所述协议数据解析服务进程注册至协议数据解析服务管理模块,以通过所述协议数据解析服务管理模块对所述协议数据解析服务进程进行生命周期管理。
进一步地,所述物联网设备支持多种通信协议,处理器1001可以用于调用存储器1005中存储的协议数据解析程序,还执行以下操作:
若所述协议数据解析服务包括多个,则将所述协议数据按照协议类型进行分类;
将分类后的协议数据分别发送至对应协议类型的协议数据解析服务。
进一步地,处理器1001可以用于调用存储器1005中存储的协议数据解析程序,还执行以下操作:
对所述协议数据解析服务进行多次实例化,得到多个实例;
基于所述多个实例,构建所述协议数据解析服务对应的分布式集群,以通过所述分布式集群对所述协议数据进行解析得到格式化数据。
进一步地,处理器1001可以用于调用存储器1005中存储的协议数据解析程序,还执行以下操作:
获取协议数据解析代码,其中,所述协议数据解析代码包括单一协议类型的数据解析代码和与物联网平台进行交互的相关代码;
对所述协议数据解析代码进行编译,得到可执行程序;
对所述可执行程序绑定相应的发布信息,并将绑定所述发布信息的可执行程序发布至协议数据解析服务程序库,以供从所述协议数据解析服务程序库中查询协议数据对应的协议数据解析服务。
基于上述硬件结构,提出本发明基于物联网的协议数据解析方法各个实施例。
本发明提供一种基于物联网的协议数据解析方法。
参照图2,图2为本发明基于物联网的协议数据解析方法第一实施例的流程示意图。
在本实施例中,该基于物联网的协议数据解析方法包括:
步骤S10,当物联网设备向物联网平台发送协议数据时,通过所述物联网平台的设备接入服务接收所述协议数据;
在本实施例中,在物联网设备接入物联网平台后,当物联网设备向物联网平台发送协议数据时,通过该物联网平台的设备接入服务接收该协议数据。其中,物联网设备为可接入物联网的设备,例如,用于获取信息的传感器设备、网关设备等,该互联网设备用于向物联网平台发送自身获取或转发的数据信息,各个物联网设备基于该物联网平台进行交互和通信。
其中,物联网平台可以为物联网云平台,用于提供大量的通信协议,支持海量的物联网设备接入,还用于开发相应的物联网应用,以在物联网数据中提取价值。具体的,物联网平台可对接收的协议数据进行存储、分发、分析等处理。
其中,协议数据为满足某种通信协议的数据,该协议数据的数据格式与其通信协议相关,此时,物联网平台需要接收统一数据格式的数据,才可以进行后续的业务处理,因此,先由设备接入服务对该协议数据进行接收。可以理解,物联网设备可能支持多种通信协议,相应的,同一物联网设备可能发送多种协议类型的协议数据。
需要说明的是,设备接入服务是物联网平台的基础模块,为物联网平台中的一个服务程序,其负责传感器等物联网设备的接入管理,其用于接收传感器上报的数据。可以理解,该设备接入服务可以在任一服务器中,例如,物联网平台本身的服务器中,或者,与物联网平台相互通信的其他服务器中,即设备接入服务交由其他服务器进行处理,具体的,可以根据实际需要进行设定。
在一实施例中,设备接入服务在接收协议数据之前,先执行初始化操作,以启动该设备接入服务。
步骤S20,从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务,其中,所述协议数据解析服务为可执行程序;
在本实施例中,在接收到协议数据之后,从协议数据解析服务程序库中查询该协议数据对应的协议数据解析服务。其中,该协议数据解析服务为可执行程序,也就是说,协议数据解析服务程序库中各个协议数据解析服务为可执行程序,该可执行程序为已经经过编译器进行编译的目标程序,即该可执行程序可直接在服务器上执行相应的解析处理。
其中,协议数据解析服务程序库为存储协议数据解析服务程序的程序库,其用于存储各种协议类型对应的服务程序,也就是说,每当有一种新协议类型应用于该物联网设备中,则可以将新开发的协议数据解析服务程序发布至该协议数据解析服务程序库。可以理解,该协议数据解析服务程序库可以位于云服务器中,也可以位于客户端处的服务器中。
其中,每种协议类型对应一个可执行程序,即每种协议类型对应一种协议数据解析服务,该可执行程序可以根据平台的不同而不同,也就是说,可以将协议数据解析代码编译成不同平台(例如,Windows、Linux、x86、arm等)下的可执行程序,
需要说明的是,协议数据解析服务为可执行程序,该协议数据解析服务需要启动,并进入服务器的进程队列中,进而通过该协议数据解析服务对应的进程实现协议数据的解析处理。
此外,还需要说明的是,开发者根据物联网设备的协议类型在线编辑数据解析代码,然后,将该数据解析代码与系统自动生成的一些代码(例如,与物联网平台进行交互的相关代码)进行融合得到协议数据解析代码,之后,对协议数据解析代码进行编译,以得到该协议数据解析服务对应的可执行程序,最后,将该可执行程序发布至协议数据解析服务程序库中,以供后续可基于该协议数据解析服务程序库获取相应的协议数据解析服务,从而有针对性地完成协议数据解析处理。其中,该数据解析代码可以采用golang语言进行编辑,当然,也可以采用类似golang语言的其他解释型语言进行编辑。
在一实施例中,可以额外设置一个协议数据解析服务管理模块,以用于查询该协议数据对应的协议数据解析服务。该协议数据解析服务管理模块还用于负责协议数据解析服务的实例化,以得到对应的服务进程,并负责这些服务进程的生命周期管理。在其他实施方式中,也可以由设备接入服务自主查询该协议数据对应的协议数据解析服务,或者由其他服务程序执行该查询任务。
步骤S30,将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据;
在获取得到该协议数据对应的协议数据解析服务之后,将该协议数据从设备接入服务发送至该协议数据解析服务,以通过该数据解析服务对该协议数据进行解析得到格式化数据。其中,格式化数据为该物联网平台能够处理的数据,也就是说,格式化数据为统一的数据格式,该统一的数据格式可以根据实际需要进行设定,例如,采用JSON数据格式作为统一的数据格式。
需要说明的是,可以通过预定义的接口(例如TCP、UDP、MQTT等)将该协议数据发送至协议数据解析服务,相应的,该协议数据解析服务对应的可执行程序也是通过该预定义的接口和物联网平台进行通信,进而实现接收原始的协议数据,并将解析后的统一格式的格式化数据发送给物联网平台进行业务处理。
步骤S40,将所述格式化数据返回至所述物联网平台,以供所述物联网平台对所述格式化数据进行处理。
在获取得到格式化数据之后,将格式化数据返回至物联网平台,以供物联网平台对该格式化数据进行处理。具体的,可以将格式化数据返回至物联网平台中的数据处理模块中进行处理,该数据处理模块只需为统一的模块即可,无需针对不同物联网设备设置不同的数据处理模块。
需要说明的是,物联网平台对格式化数据进行处理包括存储、分发、分析等处理,具体的,可以根据实际需要进行设定,此处不作限定。
本发明实施例提供一种基于物联网的协议数据解析方法,当物联网设备向物联网平台发送协议数据时,通过物联网平台的设备接入服务接收协议数据;从协议数据解析服务程序库中查询协议数据对应的协议数据解析服务,其中,协议数据解析服务为可执行程序;将协议数据发送至协议数据解析服务,以通过协议数据解析服务对协议数据进行解析得到格式化数据;将格式化数据返回至物联网平台,以供物联网平台对格式化数据进行处理。通过上述方式,在对接收到的协议数据进行解析时,可以直接查询对应协议类型的协议数据解析服务,以通过该协议数据解析服务对该协议数据进行解析,并且,该协议数据解析服务为可执行程序,即该可执行程序已经是目标设备上可以直接执行的程序,从而提高了物联网协议数据的解析效率。同时,从协议数据解析服务程序库中查询协议数据对应的协议数据解析服务,以使后续进行解析处理的协议数据解析服务进程只对应一个协议类型数据的解析处理,从而减少每个进程的资源占用,进而较少服务器的资源占用。
进一步地,基于上述第一实施例,提出本发明基于物联网的协议数据解析方法第二实施例。
在本实施例中,上述步骤S20包括:
步骤a21,通过协议数据解析服务管理模块,从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务及通信方式,其中,所述通信方式为所述设备接入服务与所述协议数据解析服务进行通信的方式;
在本实施例中,在设备接入服务接收到物联网设备发送的协议数据后,通过协议数据解析服务管理模块,从协议数据解析服务程序库中查询该协议数据对应的协议数据解析服务及通信方式,其中,该通信方式为该设备接入服务与该协议数据解析服务进行通信的方式。
其中,协议数据解析服务管理模块为对协议数据解析服务进行管理的模块,其用于查询该协议数据对应的协议数据解析服务,还用于对协议数据解析服务对应的服务程序代码进行编译和发布,以及负责协议数据解析服务的实例化,以得到对应的服务进程,并负责这些服务进程的生命周期管理,以实现启动、关闭、重启协议数据解析服务。
其中,协议数据解析服务程序库为存储协议数据解析服务程序的程序库,其用于存储各种协议类型对应的服务程序,也就是说,每当有一种新协议类型应用于该物联网设备中,则可以将新开发的协议数据解析服务程序发布至该协议数据解析服务程序库。可以理解,该协议数据解析服务程序库可以位于云服务器中,也可以位于客户端处的服务器中。
需要说明的是,通信方式为设备接入服务与协议数据解析服务进行通信的方式,而该协议数据解析服务管理模块可以提供通信方式信息,以供后续基于该通信方式,将该协议数据发送至该协议数据解析服务进行解析处理。具体的,可以通过TCP、UDP、MQTT等通信方式发送协议数据至对应的协议数据解析服务进程。
相应的,上述步骤S30包括:
步骤a31,通过所述通信方式,将所述协议数据发送至所述协议数据解析服务。
具体的,若通信方式为TCP,则通过TCP通信方式将协议数据发送至协议数据解析服务;若通信方式为UDP,则通过UDP通信方式将协议数据发送至协议数据解析服务;若通信方式为MQTT,则通过MQTT通信方式将协议数据发送至协议数据解析服务。
本实施例中,物联网平台提供一种协议数据解析服务管理模块,以负责协议数据解析服务的查询,相比在各个服务中分别查询对应的协议数据解析服务,本实施例通过协议数据解析服务管理模块进行统一管理,从而进一步提高物联网协议数据的解析效率。
进一步地,基于上述第一实施例,提出本发明基于物联网的协议数据解析方法第三实施例。
参照图3,图3为本发明基于物联网的协议数据解析方法第三实施例的流程示意图。
在本实施例中,在上述步骤S30之前,该基于物联网的协议数据解析方法还包括:
步骤S50,对所述协议数据解析服务进行实例化,以将所述协议数据解析服务对应的可执行程序从所述协议数据解析服务程序库中拷贝至目标设备,以使所述目标设备执行所述可执行程序;
在本实施例中,由于协议数据解析服务位于协议数据解析服务程序库中,在查询到对应协议数据解析服务后,还需要对协议数据解析服务进行实例化,以将协议数据解析服务对应的可执行程序从协议数据解析服务程序库中拷贝至目标设备,以使目标设备执行该可执行程序。其中,目标设备为该物联网平台中执行解析处理的设备,也就是说,协议数据解析服务是在目标设备上执行的。
需要说明的是,实例化处理是为了将协议数据解析服务从协议数据解析服务程序库中拷贝至目标设备,以供目标设备启动该协议数据解析服务对应的可执行程序,从而基于协议数据解析服务对应的服务进程完成相应的解析处理。
此外,还需要说明的是,协议数据解析服务程序库位于云服务器中,此时需要基于互联网将协议数据解析服务程序库中的协议数据解析服务发送至目标设备。或者,协议数据解析服务程序库位于本地设备中,此时需要基于局域网将协议数据解析服务程序库中的协议数据解析服务发送至目标设备。
在一实施例中,可以对协议数据解析服务进行多次实例化,以得到多个实例,从而构建协议数据解析服务对应的分布式集群,以使各个协议数据解析服务实现同步更新和复制备份,进而达到容灾和负载均衡的效果。
步骤S60,启动所述可执行程序,以得到对应的协议数据解析服务进程。
在对协议数据解析服务进行实例化之后,启动该协议数据解析服务对应的可执行程序,以得到对应的协议数据解析服务进程。其中,协议数据解析服务进程是一个单独的进程,其只包含一种协议类型数据的解析方法,所以该协议数据解析服务进程占用的资源相当少,
需要说明的是,协议数据解析服务、可执行程序、协议数据解析服务进程相互对应,其只是运行状态不一样。该协议数据解析服务进程则表示协议数据解析服务进入CPU的执行栈中,即已经被CPU开始执行了。
此外,还需要说明的是,启动可执行程序,以使协议数据解析服务等待接收协议数据,并进行相应的解析处理。
其中,上述步骤S30包括:
步骤S32,将所述协议数据发送至所述协议数据解析服务进程,以通过所述协议数据解析服务进程对所述协议数据进行解析得到格式化数据。
在本实施例中,将协议数据发送至协议数据解析服务进程,以通过协议数据解析服务进程对协议数据进行解析得到格式化数据。其中,协议数据解析服务进程对应一个协议类型的解析过程,即一个协议类型对应一个协议数据解析服务,也对应一个协议数据解析服务进程或可执行程序。
可以理解,不同协议数据解析服务进程不会互相影响,以使各个进程占用内存少,以进一步减少服务器的资源占用,进而可以同时部署多个协议数据解析服务进程。
进一步地,上述步骤S60之后,该基于物联网的协议数据解析方法还包括:
步骤A,将所述协议数据解析服务进程注册至协议数据解析服务管理模块,以通过所述协议数据解析服务管理模块对所述协议数据解析服务进程进行生命周期管理。
在本实施例中,将协议数据解析服务进程注册至协议数据解析服务管理模块,以使协议数据解析服务管理模块对该协议数据解析服务进程进行管理,从而实现对协议数据解析服务进程进行生命周期管理。
其中,协议数据解析服务管理模块为对协议数据解析服务进行管理的模块,其用于查询该协议数据对应的协议数据解析服务,还用于对协议数据解析服务对应的服务程序代码进行编译和发布,以及负责协议数据解析服务的实例化,以得到对应的服务进程,并负责这些服务进程的生命周期管理,以实现启动、关闭、重启协议数据解析服务。
其中,生命周期管理包括启动、停止、重启、关闭等操作,其用于管理协议数据解析服务的生命周期。
本实施例中,对协议数据解析服务进行实例化,以将协议数据解析服务对应的可执行程序从协议数据解析服务程序库中拷贝至目标设备,从而实现可执行程序的调用。同时,可直接启动实例化的可执行程序,即该可执行程序已经是目标设备上可以直接执行的程序,从而进一步提高了物联网协议数据的解析效率。
进一步地,基于上述第一实施例,提出本发明基于物联网的协议数据解析方法第四实施例。
在本实施例中,上述步骤S30包括:
步骤a33,若所述协议数据解析服务包括多个,则将所述协议数据按照协议类型进行分类;
在本实施例中,物联网设备支持多种通信协议,相应的,物联网设备可以向物联网平台发送多种类型的协议数据,以使设备接入服务接收多种类型的协议数据,进而从协议数据解析服务程序库中查询各种协议数据对应的协议数据解析服务,也就是说,有多种协议类型的协议数据解析服务。然后,将各种协议数据按照协议类型进行分类,以准确将协议数据发送至对应的协议数据解析服务。
步骤a34,将分类后的协议数据分别发送至对应协议类型的协议数据解析服务。
在本实施例中,将分类后的协议数据分别发送至对应协议类型的协议数据解析服务。例如,协议数据为TCP类型的数据,则对应的协议数据解析服务也是对TCP类型的数据进行解析的服务。
在一实施例中,若一个协议类型包括多个协议数据,则可以将同一协议类型的协议数据发送至同一协议数据解析服务。其中,可以创建多个协议数据解析服务进程分别对协议数据进行处理,也可以通过一个协议数据解析服务进程对协议数据进行处理。
本实施例中,对于支持多种通信协议的物联网设备,也可以提供多种对应的协议数据解析服务进行处理,以进一步提高物联网协议数据解析处理的适用性。
进一步地,基于上述第一实施例,提出本发明基于物联网的协议数据解析方法第五实施例。
在本实施例中,该基于物联网的协议数据解析方法还包括:
步骤B,对所述协议数据解析服务进行多次实例化,得到多个实例;
在本实施例中,对协议数据解析服务进行多次实例化,得到多个实例。具体的,将协议数据解析服务拷贝至多个目标设备,并在多个目标设备上分别启动该协议数据解析服务,以实现多节点的协议数据解析服务。
步骤C,基于所述多个实例,构建所述协议数据解析服务对应的分布式集群,以通过所述分布式集群对所述协议数据进行解析得到格式化数据。
在本实施例中,以多个实例作为各个分布式节点,构建该协议数据解析服务对应的分布式集群,以通过该分布式集群对协议数据进行解析得到格式化数据。
本实施例中,对协议数据解析服务进行多次实例化,以得到多个实例,并构建协议数据解析服务对应的分布式集群,以使各个协议数据解析服务实现同步更新和复制备份,进而达到容灾和负载均衡的效果。
进一步地,基于上述第一至第五实施例,提出本发明基于物联网的协议数据解析方法第六实施例。
参照图4,图4为本发明基于物联网的协议数据解析方法第六实施例的流程示意图。
在本实施例中,在上述步骤S10之前,该基于物联网的协议数据解析方法还包括:
步骤S70,获取协议数据解析代码,其中,所述协议数据解析代码包括单一协议类型的数据解析代码和与物联网平台进行交互的相关代码;
在本实施例中,获取协议数据解析代码,其中,该协议数据解析代码包括单一协议类型的数据解析代码和与物联网平台进行交互的相关代码。其中,单一协议类型的数据解析代码由在线编辑平台得到,即开发者根据协议类型或物联网设备的接口类型在线编辑数据解析代码。然后,将数据解析代码和自动生成的一些代码进行融合得到协议数据解析代码,该自动生成的代码为与物联网平台进行交互的相关代码。
在一实施例中,协议数据解析代码及数据解析代码等均可以通过golang编程语言进行开发,或者与golang语言基本相同的编译型语言。
步骤S80,对所述协议数据解析代码进行编译,得到可执行程序;
在获取协议数据解析代码之后,通过在线编译器对该协议数据解析代码进行编译,以得到目标可执行程序。其中,可执行程序为目标设备可以直接执行的程序,例如编译成机器语言。
步骤S90,对所述可执行程序绑定相应的发布信息,并将绑定所述发布信息的可执行程序发布至协议数据解析服务程序库,以供从所述协议数据解析服务程序库中查询协议数据对应的协议数据解析服务。
在本实施例中,为得知发布的可执行程序的分布信息,应该对可执行程序绑定相应的发布信息,并将绑定发布信息的可执行程序发布至协议数据解析服务程序库中,以供从协议数据解析服务程序库中查询协议数据对应的协议数据解析服务。
其中,发布信息包括物联网设备类型、协议类型、发布日期、发布者名称、发布版本等,具体的,可以根据实际需要设定,此处不作具体限定。
需要说明的是,协议数据解析服务程序库为存储协议数据解析服务程序的程序库,其用于存储各种协议类型对应的服务程序,也就是说,每当有一种新协议类型应用于该物联网设备中,则可以将新开发的协议数据解析服务程序发布至该协议数据解析服务程序库。可以理解,该协议数据解析服务程序库可以位于云服务器中,也可以位于客户端处的服务器中。
本实施例中,开发者只需要实现与协议类型相关的数据解析代码,剩余其他代码可自动生成,然后编译打包成一个可执行程序,以供后续可直接执行该可执行程序。同时,开发者自主编辑数据解析代码,可以实现多种协议类型的解析处理,从而进一步提高物联网协议数据解析的适用性。
本发明还提供一种基于物联网的协议数据解析系统,该基于物联网的协议数据解析系统包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的协议数据解析程序,所述协议数据解析程序被所述处理器执行时实现如以上任一项实施例所述的基于物联网的协议数据解析方法的步骤。
本发明基于物联网的协议数据解析系统的具体实施例与上述基于物联网的协议数据解析方法各实施例基本相同,在此不作赘述。
本发明还提供一种计算机可读存储介质,该计算机可读存储介质上存储有协议数据解析程序,所述协议数据解析程序被处理器执行时实现如以上任一项实施例所述的基于物联网的协议数据解析方法的步骤。
本发明计算机可读存储介质的具体实施例与上述基于物联网的协议数据解析方法各实施例基本相同,在此不作赘述。
本发明还提供一种计算机程序产品,所述计算机程序产品包括计算机程序,所述计算机程序产品被处理器执行时实现如以上任一项实施例所述的基于物联网的协议数据解析方法的步骤。
本发明计算机程序产品的具体实施例与上述基于物联网的协议数据解析方法各实施例基本相同,在此不作赘述。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者系统不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者系统所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者系统中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在如上所述的一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (10)
1.一种基于物联网的协议数据解析方法,其特征在于,所述基于物联网的协议数据解析方法包括以下步骤:
当物联网设备向物联网平台发送协议数据时,通过所述物联网平台的设备接入服务接收所述协议数据;
从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务,其中,所述协议数据解析服务为可执行程序;
将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据;
将所述格式化数据返回至所述物联网平台,以供所述物联网平台对所述格式化数据进行处理。
2.如权利要求1所述的基于物联网的协议数据解析方法,其特征在于,所述从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务的步骤包括:
通过协议数据解析服务管理模块,从协议数据解析服务程序库中查询所述协议数据对应的协议数据解析服务及通信方式,其中,所述通信方式为所述设备接入服务与所述协议数据解析服务进行通信的方式;
其中,所述将所述协议数据发送至所述协议数据解析服务的步骤包括:
通过所述通信方式,将所述协议数据发送至所述协议数据解析服务。
3.如权利要求1所述的基于物联网的协议数据解析方法,其特征在于,所述将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据的步骤之前,还包括:
对所述协议数据解析服务进行实例化,以将所述协议数据解析服务对应的可执行程序从所述协议数据解析服务程序库中拷贝至目标设备,以使所述目标设备执行所述可执行程序;
启动所述可执行程序,以得到对应的协议数据解析服务进程;
其中,所述将所述协议数据发送至所述协议数据解析服务,以通过所述协议数据解析服务对所述协议数据进行解析得到格式化数据的步骤包括:
将所述协议数据发送至所述协议数据解析服务进程,以通过所述协议数据解析服务进程对所述协议数据进行解析得到格式化数据。
4.如权利要求3所述的基于物联网的协议数据解析方法,其特征在于,所述启动所述可执行程序,以得到对应的协议数据解析服务进程的步骤之后,还包括:
将所述协议数据解析服务进程注册至协议数据解析服务管理模块,以通过所述协议数据解析服务管理模块对所述协议数据解析服务进程进行生命周期管理。
5.如权利要求1所述的基于物联网的协议数据解析方法,其特征在于,所述物联网设备支持多种通信协议,所述将所述协议数据发送至所述协议数据解析服务的步骤包括:
若所述协议数据解析服务包括多个,则将所述协议数据按照协议类型进行分类;
将分类后的协议数据分别发送至对应协议类型的协议数据解析服务。
6.如权利要求1所述的基于物联网的协议数据解析方法,其特征在于,所述基于物联网的协议数据解析方法还包括:
对所述协议数据解析服务进行多次实例化,得到多个实例;
基于所述多个实例,构建所述协议数据解析服务对应的分布式集群,以通过所述分布式集群对所述协议数据进行解析得到格式化数据。
7.如权利要求1至6中任一项所述的基于物联网的协议数据解析方法,其特征在于,所述当物联网设备向物联网平台发送协议数据时,通过所述物联网平台的设备接入服务接收所述协议数据的步骤之前,还包括:
获取协议数据解析代码,其中,所述协议数据解析代码包括单一协议类型的数据解析代码和与物联网平台进行交互的相关代码;
对所述协议数据解析代码进行编译,得到可执行程序;
对所述可执行程序绑定相应的发布信息,并将绑定所述发布信息的可执行程序发布至协议数据解析服务程序库,以供从所述协议数据解析服务程序库中查询协议数据对应的协议数据解析服务。
8.一种基于物联网的协议数据解析系统,其特征在于,所述基于物联网的协议数据解析系统包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的协议数据解析程序,所述协议数据解析程序被所述处理器执行时实现如权利要求1至7中任一项所述的基于物联网的协议数据解析方法的步骤。
9.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有协议数据解析程序,所述协议数据解析程序被处理器执行时实现如权利要求1至7中任一项所述的基于物联网的协议数据解析方法的步骤。
10.一种计算机程序产品,其特征在于,所述计算机程序产品包括计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7中任一项所述的基于物联网的协议数据解析方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110464284.XA CN113179269B (zh) | 2021-04-27 | 2021-04-27 | 基于物联网的协议数据解析方法、系统、介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110464284.XA CN113179269B (zh) | 2021-04-27 | 2021-04-27 | 基于物联网的协议数据解析方法、系统、介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113179269A true CN113179269A (zh) | 2021-07-27 |
CN113179269B CN113179269B (zh) | 2023-04-28 |
Family
ID=76926886
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110464284.XA Active CN113179269B (zh) | 2021-04-27 | 2021-04-27 | 基于物联网的协议数据解析方法、系统、介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113179269B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113923272A (zh) * | 2021-09-16 | 2022-01-11 | 珠海格力电器股份有限公司 | 数据解析方法、装置和服务器设备 |
CN114710572A (zh) * | 2022-03-31 | 2022-07-05 | 深圳奇迹智慧网络有限公司 | 数据处理方法、装置及计算机存储介质 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7401326B1 (en) * | 2001-10-24 | 2008-07-15 | Finisar Corporation | Compiling protocol analysis code using protocol database |
CN102571732A (zh) * | 2010-12-30 | 2012-07-11 | 中国移动通信集团公司 | 一种处理传感器协议信息的方法、装置和系统 |
CN107704245A (zh) * | 2017-09-21 | 2018-02-16 | 深圳市麦斯杰网络有限公司 | 协议接入方法、装置及计算机可读存储介质 |
CN109040144A (zh) * | 2018-10-19 | 2018-12-18 | 京信通信系统(中国)有限公司 | 物联网网关数据处理方法、装置、存储介质及网关设备 |
CN111427664A (zh) * | 2020-03-25 | 2020-07-17 | 杭州电子科技大学 | 基于容器的协议解析方法、装置、系统以及存储介质 |
CN111447227A (zh) * | 2020-03-27 | 2020-07-24 | 四川虹美智能科技有限公司 | 物联网设备的协议解析方法及装置 |
CN112422588A (zh) * | 2021-01-25 | 2021-02-26 | 北京工业大数据创新中心有限公司 | 一种物联网设备信息处理方法及系统 |
CN112565443A (zh) * | 2020-12-08 | 2021-03-26 | 中煤航测遥感集团有限公司 | 物联网数据解析方法、装置、设备及存储介质 |
-
2021
- 2021-04-27 CN CN202110464284.XA patent/CN113179269B/zh active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7401326B1 (en) * | 2001-10-24 | 2008-07-15 | Finisar Corporation | Compiling protocol analysis code using protocol database |
CN102571732A (zh) * | 2010-12-30 | 2012-07-11 | 中国移动通信集团公司 | 一种处理传感器协议信息的方法、装置和系统 |
CN107704245A (zh) * | 2017-09-21 | 2018-02-16 | 深圳市麦斯杰网络有限公司 | 协议接入方法、装置及计算机可读存储介质 |
CN109040144A (zh) * | 2018-10-19 | 2018-12-18 | 京信通信系统(中国)有限公司 | 物联网网关数据处理方法、装置、存储介质及网关设备 |
CN111427664A (zh) * | 2020-03-25 | 2020-07-17 | 杭州电子科技大学 | 基于容器的协议解析方法、装置、系统以及存储介质 |
CN111447227A (zh) * | 2020-03-27 | 2020-07-24 | 四川虹美智能科技有限公司 | 物联网设备的协议解析方法及装置 |
CN112565443A (zh) * | 2020-12-08 | 2021-03-26 | 中煤航测遥感集团有限公司 | 物联网数据解析方法、装置、设备及存储介质 |
CN112422588A (zh) * | 2021-01-25 | 2021-02-26 | 北京工业大数据创新中心有限公司 | 一种物联网设备信息处理方法及系统 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113923272A (zh) * | 2021-09-16 | 2022-01-11 | 珠海格力电器股份有限公司 | 数据解析方法、装置和服务器设备 |
CN114710572A (zh) * | 2022-03-31 | 2022-07-05 | 深圳奇迹智慧网络有限公司 | 数据处理方法、装置及计算机存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN113179269B (zh) | 2023-04-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7836439B2 (en) | System and method for extending a component-based application platform with custom services | |
US8849892B2 (en) | Method and system for brokering messages in a distributed system | |
US9760415B2 (en) | Code service for language-independent dispatch | |
EP1818820A1 (en) | System and method for installing custom services on a component-based application platform | |
CN110658794B (zh) | 一种制造执行系统 | |
US7424722B2 (en) | Method and system for creating a dynamic OGSI service proxy framework using runtime introspection of an OGSI service | |
US8701129B2 (en) | Web API server program, web API publication method | |
EP3837604A1 (en) | In situ triggered function as a service within a service mesh | |
US20120226737A1 (en) | Method and system for reducing service overhead in service oriented architectures | |
CN113179269B (zh) | 基于物联网的协议数据解析方法、系统、介质 | |
US20200183657A1 (en) | Apparatus and method for executing function | |
CN108804100B (zh) | 创建界面元素的方法、装置、存储介质及移动终端 | |
CN113835911A (zh) | 内网穿透代理方法、系统、主机及计算机可读存储介质 | |
US9996344B2 (en) | Customized runtime environment | |
US10268496B2 (en) | System and method for supporting object notation variables in a process defined by a process execution language for execution in a SOA middleware environment | |
WO2023083071A1 (zh) | 视图交互方法、装置、电子设备及计算机可读介质 | |
US20160291941A1 (en) | System and method for supporting javascript as an expression language in a process defined by a process execution language for execution in a soa middleware environment | |
CN114675821B (zh) | 一种基于低代码的服务标准化系统及方法 | |
WO2006089387A1 (en) | Extending access to local software of a wireless device | |
CN114938396A (zh) | 服务调用请求的路由方法、创建服务的方法及装置 | |
WO2006089386A1 (en) | Simulating an application for subsequent deployment to a device | |
CN114745260B (zh) | 内容分发网络的计算力增强方法、装置、设备及存储介质 | |
CN108804101B (zh) | 创建界面元素的方法、装置、存储介质及移动终端 | |
Dutt | IPC Through Sockets | |
WO2023147882A1 (en) | Version-dependency information for management of a network service |
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 |