CN114070801A - 报文处理方法、报文传输方法、装置及电子设备 - Google Patents
报文处理方法、报文传输方法、装置及电子设备 Download PDFInfo
- Publication number
- CN114070801A CN114070801A CN202111392822.5A CN202111392822A CN114070801A CN 114070801 A CN114070801 A CN 114070801A CN 202111392822 A CN202111392822 A CN 202111392822A CN 114070801 A CN114070801 A CN 114070801A
- Authority
- CN
- China
- Prior art keywords
- message
- target
- queue
- messages
- current
- 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.)
- Pending
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/50—Queue scheduling
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本申请提供了一种报文处理方法、报文传输方法、装置及电子设备,其中,该方法包括:对接收到的报文进行识别,以确定出当前目标类报文;将该当前目标类报插入第一队列中的目标位置;判断该第一队列中的目标类报文的数量是否与该目标类报文对应的分片数相同;若该第一队列中的目标类报文的数量与该目标类报文对应的分片数相同,则将该第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
Description
技术领域
本申请涉及数据处理技术领域,具体而言,涉及一种报文处理方法、报文传输方法、装置及电子设备。
背景技术
随着网络的高速发展,对网络设备的性能要求也越来越高,随之出现了一种机框式设备。该机框式设备中可以包含多个业务处理板卡,业务处理板卡与业务处理板卡之间通过内部网络相连,业务处理板卡之间通常需要交互较大量的数据,这些数据的长度大小不一致。由于机框式设备的网络硬件存在的限制,发送的数据长度存在一些限制。
发明内容
有鉴于此,本申请实施例的目的在于提供一种报文处理方法、报文传输方法、装置及电子设备。能够传输的数据长度存在限制的问题。
第一方面,本申请实施例提供了一种报文处理方法,包括:
对接收到的报文进行识别,以确定出当前目标类报文;
将所述当前目标类报文插入第一队列中的目标位置;
判断所述第一队列中的目标类报文的数量是否与所述目标类报文对应的分片数相同;
若所述第一队列中的目标类报文的数量与所述目标类报文对应的分片数相同,则将所述第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
在一可选的实施方式中,所述将所述当前目标类报文插入第一队列中的目标位置,包括:
确定所述第一队列中是否存在与所述当前目标类报文所属同一原始报文的目标类报文;
若所述第一队列中存在与所述当前目标类报文所属同一原始报文的目标类报文,将所述当前目标类报文插入所述第一队列中一份或多份所述目标类报文间的目标位置。
在一可选的实施方式中,所述将所述当前目标类报文插入所述第一队列中一份或多份所述目标类报文间的目标位置,包括:
根据所述当前目标类报文的报文头,确定出所述当前目标类报文的当前偏移量;
根据所述当前偏移量,以及所述第一队列中与所述当前目标类报文所属同一原始报文的其它目标类报文的偏移量进行排序,以确定出所述当前目标类报文在所述第一队列中的目标位置;
将所述当前目标类报文插入所述目标位置。
在一可选的实施方式中,所述方法还包括:
若所述第一队列中不存在与所述当前目标类报文所属同一原始报文的目标类报文,在所述第一队列中确定出存储资源,将所述当前目标类报文存入所述存储资源处。
在一可选的实施方式中,所述方法还包括:
按照预设时间规律判断所述第一队列中的各组报文中的首次存入时间是否超过预设时长;
若存在首次存入时间超过预设时长的超时报文,则将所述超时报文以及所述超时报文相关的其它报文从所述第一队列中删除。
在一可选的实施方式中,所述方法还包括:
判断所述完整报文的长度是否与所述目标类报文的报文头中记录的报文总长度相同;
若所述完整报文的长度与所述目标类报文的报文头中记录的报文总长度不相同,将所述完整报文从所述第二队列中删除。
第二方面,本申请实施例提供一种报文传输方法,应用于电子设备,所述电子设备包括发送端和接收端,所述报文传输方法包括:
通过所述接收端将待发送的长报文分割成多份目标类报文;
通过所述接收端将所述目标类报文传输给所述接收端;
通过所述接收端将接收到的当前目标类报插入第一队列中的目标位置;
通过所述接收端判断所述第一队列中的目标类报文的数量是否与所述目标类报文对应的分片数相同;
若所述第一队列中的目标类报文的数量与所述目标类报文对应的分片数相同,通过所述接收端将所述第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
在一可选的实施方式中,所述通过所述接收端将待发送的长报文分割成多份目标类报文,包括:
通过所述接收端,根据预设数据长度将待发送的长报文分割成多份目标类报文;
根据预定义报文头格式对多份所述目标类报文进行封装。
第三方面,本申请实施例提供一种数据处理装置,包括:
识别模块,用于对接收到的报文进行识别,以确定出当前目标类报文;
插入模块,用于将所述当前目标类报文插入第一队列中的目标位置;
第一判断模块,用于判断所述第一队列中的目标类报文的数量是否与所述目标类报文对应的分片数相同;
重组模块,用于若所述第一队列中的目标类报文的数量与所述目标类报文对应的分片数相同,则将所述第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
第四方面,本申请实施例提供一种电子设备,包括:处理器、存储器,所述存储器存储有所述处理器可执行的机器可读指令,当电子设备运行时,所述机器可读指令被所述处理器执行时执行上述的报文处理方法或报文传输方法中的步骤。
第五方面,本申请实施例提供一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行上述的报文处理方法或报文传输方法中的步骤。
本申请实施例提供的报文处理方法、报文传输方法、装置、电子设备及计算机可读存储介质,采用接收分片后的短报文,并将短报文通过排序和重组的方式实现恢复成长报文,从而可以实现不限定传输的报文的长度,能够更加自由接收不同长度的报文。
为使本申请的上述目的、特征和优点能更明显易懂,下文特举实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本申请实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本申请的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1为本申请实施例提供的电子设备的方框示意图;
图2为本申请实施例提供的报文处理方法的流程图;
图3为本申请实施例提供的报文处理装置的功能模块示意图;
图4为本申请实施例提供的报文传输方法的流程图。
具体实施方式
下面将结合本申请实施例中附图,对本申请实施例中的技术方案进行描述。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本申请的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
发明人了解到,由于机框式设备的网络硬件存在的限制,传输的数据长度不可能很大,为了简化发送端和接收端的开发工作,快速处理和传输这种超长数据,需要一种机制来高效地处理这种超长报文。
基于上述研究,一种处理方式是,可以通过发送端在发送数据时,直接调用硬件驱动提供的发送接口,根据硬件对收发数据长度的限制,约定可以发送的最大数据长度。但是采用这种处理方式,数据发送端需要对要发送的数据进行长度限制,也就限制了发送端进行业务开发的灵活性。
另一种处理方式是,可以通过发送端在发送数据时,使用系统提供的数据发送接口,超长报文由系统协议栈负责数据分片,在接收端同样由系统协议栈负责数据重组。采用这种处理方式,数据发送经过系统协议栈的处理,中间会涉及较多的操作,这无疑增加了发送过程中的性能消耗。
基于上述背景,本申请实施例提供了一种报文处理方法、报文传输方法、装置、电子设备及计算机可读存储介质,能够使用系统提供的数据发送接口,且不需要太多性能消耗的情况下,实现长报文的传输及处理。下面通过一些实施例进行描述。
为便于对本实施例进行理解,首先对执行本申请实施例所公开的报文处理方法和报文传输方法的电子设备进行详细介绍。
如图1所示,是电子设备的方框示意图。电子设备100可以包括存储器111和处理器113。本领域普通技术人员可以理解,图1所示的结构仅为示意,其并不对电子设备100的结构造成限定。例如,电子设备100还可包括比图1中所示更多或者更少的组件,或者具有与图1所示不同的配置。
上述的存储器111、处理器113各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。上述的处理器113用于执行存储器中存储的可执行模块。
其中,存储器111可以是,但不限于,随机存取存储器(Random Access Memory,简称RAM),只读存储器(Read Only Memory,简称ROM),可编程只读存储器(ProgrammableRead-Only Memory,简称PROM),可擦除只读存储器(Erasable Programmable Read-OnlyMemory,简称EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-OnlyMemory,简称EEPROM)等。其中,存储器111用于存储程序,所述处理器113在接收到执行指令后,执行所述程序,本申请实施例任一实施例揭示的过程定义的电子设备100所执行的方法可以应用于处理器113中,或者由处理器113实现。
上述的处理器113可能是一种集成电路芯片,具有信号的处理能力。上述的处理器113可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(digital signalprocessor,简称DSP)、专用集成电路(Application Specific Integrated Circuit,简称ASIC)、现场可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本申请实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
本实施例中,电子设备100中可以包括多块业务处理板卡,每一块业务处理办卡可以包括存储器和处理器。各个业务处理板卡之间可以传输报文。在两个业务处理板卡之间传输报文时,发送报文的业务处理板卡称之为发送端,接收报文的业务处理板卡称之为接收端。
本实施例中的电子设备100可以用于执行本申请实施例提供的各个方法中的各个步骤。下面通过几个实施例详细描述报文处理方法和报文传输方法的实现过程。
请参阅图2,是本申请实施例提供的报文处理方法的流程图。本实施例中的报文处理方法可以应用于电子设备中的接收端。下面将对图2所示的具体流程进行详细阐述。
步骤210,对接收到的报文进行识别,以确定出当前目标类报文。
当前目标类报文的报文头可以是按照预定义的格式配置。
可选地,目标类报文的报文头可以包括:报文标识号、报文总长度、业务标识号、当前报文长度、分片数量等信息。
示例性地,报文标识号可以使用16比特表示。同一份长报文分片得到的多份目标类报文的报文标识号相同。属于不同长报文下的短报文的报文标识号不同。
报文总长度可以表示报文分片之前的原始长报文的长度。示例性地,该报文总长度可以使用16比特表示。
示例性地,业务标识号用于表示该当前目标类报文所属的具体业务。该业务标识号可以使用16比特表示。
示例性地,该当前报文长度表示当前接收到的当前目标类报文的长度。该当前报文长度可以使用16比特表示。
示例性地,该分片数量用于表示当前目标类报文对应的原始长报文被分片的总数量。该分片数量可以使用16比特表示。
本实施例中,与目标类报文类别相同的报文的以太网头中TYPE字段可以设置为指定字符串。例如,TYPE字段可以为0x8888。
可选地,目标类报文的报文头中还可以包括DF字段和MF字段。
该DF字段可以用于表示目标类报文是否被分片后的报文。该MF字段用于表示目标类报文是否是最后一片报文。
可选地,该DF字段可以使用1比特表示,该DF字段为0时,表示报文为分片报文,该DF字段为1时,表示报文为不分片报文。
可选地,该MF字段可以使用1比特表示,该MF字段为0时,表示报文为最后一片,该MF字段为时,表示报文为更多分片。
步骤220,将当前目标类报文插入第一队列中的目标位置。
本实施例中,该接收端中可以运行有收包线程,该收包线程可以根据当前目标类报文的报文头中的信息,确定出该当前目标类报文所应该插入的目标位置。
当第一队列中若不存在与当前目标类报文所属同一原始报文的目标类报文时,可以在第一队列中确定出存储资源,将当前目标类报文存入存储资源处。示例性地,将当前目标类报文作为首份分片报文存入该第一队列中,并记录当前目标类报文的存入时间。
在后续接收到该当前目标类报文所属同一原始报文的目标类报文时,可以将接收到的目标类报文存入该存储资源中。
当第一队列中若存在与当前目标类报文所属同一原始报文的目标类报文时,将当前目标类报文插入第一队列中一份或多份目标类报文间的目标位置。
可选地,可以通过以下方式确定出当前目标类报文的目标位置:根据当前目标类报文的报文头,确定出当前目标类报文的当前偏移量;根据当前偏移量,以及第一队列中与当前目标类报文所属同一原始报文的其它目标类报文的偏移量进行排序,以确定出当前目标类报文在第一队列中的目标位置;将当前目标类报文插入目标位置。
示例性地,可以采用插序算法将收到的当前目标类报文插入到合适的目标位置上。
可选地,可以通过当前目标类报文的报文头中的报文标识号,以及第一队列中的各个报文的报文头中的报文标识号进行对比,以确定出第一队列中是否存在与当前目标类报文所属同一原始报文的目标类报文。
可选地,在每次存入第一队列报文时,可以对存入第一队列中的报文的报文标识和报文数量进行记录,形成报文记录数据。可以根据报文记录数据,确定出第一队列中是否存在与当前目标类报文所属同一原始报文的目标类报文。
进一步地,上述的报文记录数据中可以存储各个原始报文对应的首份存入第一队列中的存入时间。
步骤230,判断第一队列中的目标类报文的数量是否与目标类报文对应的分片数相同。
若第一队列中的目标类报文的数量与目标类报文对应的分片数相同,则执行步骤240。
示例性地,该目标类报文的报文头上可以记录有所属的原始报文被分片的分片数量。可以根据该第一队列中存放的目标类报文的数量,与报文头上可以记录有所属的原始报文被分片的分片数量进行对比,以确定出第一队列中的目标类报文的数量是否与目标类报文对应的分片数相同。
示例性地,每次存入一目标类报文时,使用一统计计数器对存入的目标类报文的数量进行更新,通过将该统计计数器中的值与报文头上可以记录有所属的原始报文被分片的分片数量进行对比,从而可以确定出第一队列中的目标类报文的数量是否与目标类报文对应的分片数相同。
本实施例中,第一队列可以用于存放未接收完全的报文。
步骤240,将第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
所属同一原始报文的目标类报文,根据报文头中记录的偏移量的大小,将多份目标类报文拼接成原始报文。该原始报文可以是超长数据报文。
本实施例中,第二队列可以用于存放接收完全后的报文,并将接收到的多份报文重组成完整报文。
示例性地,该接收端可以运行有重组线程,可以通过该重组线程对该第二队列中的所有目标类报文进行重组。
考虑如果第一队列不限时间的等待接收报文,可能会导致第一队列的资源浪费。例如,当第一分片报文丢失去,其它报文一直存放在第一队列中,则会导致第一队列中的存储资源一直被占用,且其它报文也能够等到该第一分片报文,也就不能够组成完整的报文。基于上述研究,本申请实施例中的报文处理方法还可以包括步骤250和步骤260。
步骤250,按照预设时间规律判断第一队列中的各组报文中的首次存入时间是否超过预设时长。
示例性地,上述的预设时间规律可以是每隔指定时长。例如,该指定时长可以是50ms、100ms、200ms等时长。
可选地,可以按照预设时间规律获取记录第一队列的报文情况的报文记录数据,根据该报文记录数据确定出各组报文的首次存入时间是否超过预设时长。
该预设时长可以是按需设置的时长,例如,该预设时长可以是20s、1min等时长。
步骤260,若存在首次存入时间超过预设时长的超时报文,则将超时报文以及超时报文相关的其它报文从第一队列中删除。
超时报文相关的其它报文可以表示与该超时报文的报文标识号相同的报文。
示例性地,如果报文标识号为A的报文首次存入时间超过了预设时长,则可以将报文标识号为A的报文作为超时报文,将报文标识号为A的所有报文从该第一队列中删除。
可选地,在每次删除第一队列中的报文后,还可以对报文记录数据进行更新。
可选地,该接收端中可以运行有一超时管理线程,通过该超时管理线程执行步骤250和步骤260实现对第一队列中的报文是否超时进行监控。
考虑如果直接将第二队列中重组的完整报文,可能会存在完整报文并不完整的情况。例如,第一队列中转存的目标类报文的数量相同,但是部分目标类报文的长度与原始报文分片得到的报文存在不同,则会导致重组的完整报文并不完整。基于上述研究,本申请实施例提供的报文处理方法还可以包括步骤270至步骤290。
步骤270,判断完整报文的长度是否与目标类报文的报文头中记录的报文总长度相同。
该报文总长度为上述的当前目标类报文所属的原始报文的长度。
示例性地,该报文头中的报文总长度可以是在分片原始报文时,写入的数据。
步骤280,若完整报文的长度与目标类报文的报文头中记录的报文总长度不相同,将完整报文从第二队列中删除。
步骤290,若完整报文的长度与目标类报文的报文头中记录的报文总长度相同,将完整报文发送给应用层。
可选地,在每次删除第二队列中的报文,或者将完整报文发送给应用层后,还可以对报文记录数据进行更新。
在一些可选的实施方式中,报文记录数据可以包括第一报文记录数据和第二报文记录数据。使用第一报文记录数据记录第一队列中的报文情况,使用第二报文记录数据记录第二队列中的报文情况。
在本申请实施例提供的报文处理方法中,采用接收分片后的短报文,并将短报文通过排序和重组的方式实现恢复成长报文,从而可以实现不限定传输的报文的长度,能够更加自由接收不同长度的报文。
进一步地,还可以对第一队列中的报文的等待时间进行监控,可以避免长时间等待重组报文,导致资源的占用。
基于同一申请构思,本申请实施例中还提供了与报文处理方法对应的报文处理装置,由于本申请实施例中的装置解决问题的原理与前述的报文处理方法实施例相似,因此本实施例中的装置的实施可以参见上述方法的实施例中的描述,重复之处不再赘述。
请参阅图3,是本申请实施例提供的报文处理装置的功能模块示意图。本实施例中的报文处理装置中的各个模块用于执行上述方法实施例中的各个步骤。报文处理装置包括:识别模块310、插入模块320、第一判断模块330以及重组模块340;其中,
识别模块310,用于对接收到的报文进行识别,以确定出当前目标类报文;
插入模块320,用于将当前目标类报文插入第一队列中的目标位置;
第一判断模块330,用于判断第一队列中的目标类报文的数量是否与目标类报文对应的分片数相同;
重组模块340,用于若第一队列中的目标类报文的数量与目标类报文对应的分片数相同,则将第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
一种可选的实施方式中,插入模块320,用于:
确定第一队列中是否存在与当前目标类报文所属同一原始报文的目标类报文;
若第一队列中存在与当前目标类报文所属同一原始报文的目标类报文,将当前目标类报文插入第一队列中一份或多份目标类报文间的目标位置。
一种可选的实施方式中,插入模块320,用于:
根据当前目标类报文的报文头,确定出当前目标类报文的当前偏移量;
根据当前偏移量,以及第一队列中与当前目标类报文所属同一原始报文的其它目标类报文的偏移量进行排序,以确定出当前目标类报文在第一队列中的目标位置;
将当前目标类报文插入目标位置。
一种可选的实施方式中,插入模块320,还用于:
若第一队列中不存在与当前目标类报文所属同一原始报文的目标类报文,在第一队列中确定出存储资源,将当前目标类报文存入存储资源处。
一种可选的实施方式中,本实施例提供的报文处理装置还包括:
第二判断模块,用于按照预设时间规律判断第一队列中的各组报文中的首次存入时间是否超过预设时长;
第一删除模块,用于若存在首次存入时间超过预设时长的超时报文,则将超时报文以及超时报文相关的其它报文从第一队列中删除。
一种可选的实施方式中,本实施例提供的报文处理装置还包括:
第三判断模块,用于判断完整报文的长度是否与目标类报文的报文头中记录的报文总长度相同;
第二删除模块,用于若完整报文的长度与目标类报文的报文头中记录的报文总长度不相同,将完整报文从第二队列中删除。
请参阅图4,是本申请实施例提供的报文传输方法的流程图。本实施例中的报文传输方法存在与前述的报文处理方法类似之处和不同之处,不同之处在于,本实施例提供的报文传输方法是应用于电子设备中,该电子设备包括发送端和接收端,上述的报文处理方法仅应用于接收端。下面将对图4所示的具体流程进行详细阐述。
步骤410,通过接收端将待发送的长报文分割成多份目标类报文。
可选地,通过接收端,根据预设数据长度将待发送的长报文分割成多份目标类报文;根据预定义报文头格式对多份目标类报文进行封装。
可选地,该发送端可以获取硬件约定可以发送的最大数据长度,将该最大数据长作为预设数据长度。
示例性地,该待发送的长报文可以是超长数据报文。
将报文分割后的超长数据报文的每一片目标类报文,对目标类报文封装自定义报文头,填充以太网头,并将以太网头的TYPE字段设置成指定字符串,例如,该指定字符串可以是特殊值0x8888。
本实施例中,该自定义报文头的内容可以参见上述报文处理方法中关于报文头的描述。
该发送端可以将封装好的目标类报文传输给接收端。
步骤420,通过接收端将接收到的当前目标类报插入第一队列中的目标位置。
步骤430,通过接收端判断第一队列中的目标类报文的数量是否与目标类报文对应的分片数相同。
若第一队列中的目标类报文的数量与目标类报文对应的分片数相同,则执行步骤440。
步骤440,通过接收端将第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
本实施例提供的报文传输方法存在与前述的报文处理方法类似之处,类似之处可以参阅前面的报文处理方法实施例中的描述,在此不再赘述。在本申请实施例提供的报文传输方法中,在传输之前可以先将报文分片,将短报文通过排序和重组的方式实现恢复成长报文,从而可以实现不限定传输的报文的长度,能够更加自由接收和传输不同长度的报文。
进一步地,还可以对第一队列中的报文的等待时间进行监控,可以避免长时间等待重组报文,导致资源的占用。
进一步地,由于在传输之前,发送端可以先将报文进行分片处理,因此即使报文的长度大于硬件约定的最大数据长度,也可以实现传输,也就无需约定发送的最大数据长度,简化了数据收发端的开发任务。
此外,本申请实施例还提供一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行上述方法实施例中所述的报文处理方法或报文传输方法中的步骤。
本申请实施例所提供的报文处理方法和报文传输方法的计算机程序产品,包括存储了程序代码的计算机可读存储介质,所述程序代码包括的指令可用于执行上述方法实施例中所述的报文处理方法或报文传输方法中的步骤,具体可参见上述方法实施例,在此不再赘述。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本申请的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
另外,在本申请各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上所述仅为本申请的优选实施例而已,并不用于限制本申请,对于本领域的技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以权利要求的保护范围为准。
Claims (11)
1.一种报文处理方法,其特征在于,包括:
对接收到的报文进行识别,以确定出当前目标类报文;
将所述当前目标类报文插入第一队列中的目标位置;
判断所述第一队列中的目标类报文的数量是否与所述目标类报文对应的分片数相同;
若所述第一队列中的目标类报文的数量与所述目标类报文对应的分片数相同,则将所述第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
2.根据权利要求1所述的方法,其特征在于,所述将所述当前目标类报文插入第一队列中的目标位置,包括:
确定所述第一队列中是否存在与所述当前目标类报文所属同一原始报文的目标类报文;
若所述第一队列中存在与所述当前目标类报文所属同一原始报文的目标类报文,将所述当前目标类报文插入所述第一队列中一份或多份所述目标类报文间的目标位置。
3.根据权利要求2所述的方法,其特征在于,所述将所述当前目标类报文插入所述第一队列中一份或多份所述目标类报文间的目标位置,包括:
根据所述当前目标类报文的报文头,确定出所述当前目标类报文的当前偏移量;
根据所述当前偏移量,以及所述第一队列中与所述当前目标类报文所属同一原始报文的其它目标类报文的偏移量进行排序,以确定出所述当前目标类报文在所述第一队列中的目标位置;
将所述当前目标类报文插入所述目标位置。
4.根据权利要求2所述的方法,其特征在于,所述方法还包括:
若所述第一队列中不存在与所述当前目标类报文所属同一原始报文的目标类报文,在所述第一队列中确定出存储资源,将所述当前目标类报文存入所述存储资源处。
5.根据权利要求2所述的方法,其特征在于,所述方法还包括:
按照预设时间规律判断所述第一队列中的各组报文中的首次存入时间是否超过预设时长;
若存在首次存入时间超过预设时长的超时报文,则将所述超时报文以及所述超时报文相关的其它报文从所述第一队列中删除。
6.根据权利要求1所述的方法,其特征在于,所述方法还包括:
判断所述完整报文的长度是否与所述目标类报文的报文头中记录的报文总长度相同;
若所述完整报文的长度与所述目标类报文的报文头中记录的报文总长度不相同,将所述完整报文从所述第二队列中删除。
7.一种报文传输方法,其特征在于,应用于电子设备,所述电子设备包括发送端和接收端,所述报文传输方法包括:
通过所述接收端将待发送的长报文分割成多份目标类报文;
通过所述接收端将所述目标类报文传输给所述接收端;
通过所述接收端将接收到的当前目标类报插入第一队列中的目标位置;
通过所述接收端判断所述第一队列中的目标类报文的数量是否与所述目标类报文对应的分片数相同;
若所述第一队列中的目标类报文的数量与所述目标类报文对应的分片数相同,通过所述接收端将所述第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
8.根据权利要求7所述的方法,其特征在于,所述通过所述接收端将待发送的长报文分割成多份目标类报文,包括:
通过所述接收端,根据预设数据长度将待发送的长报文分割成多份目标类报文;
根据预定义报文头格式对多份所述目标类报文进行封装。
9.一种数据处理装置,其特征在于,包括:
识别模块,用于对接收到的报文进行识别,以确定出当前目标类报文;
插入模块,用于将所述当前目标类报文插入第一队列中的目标位置;
第一判断模块,用于判断所述第一队列中的目标类报文的数量是否与所述目标类报文对应的分片数相同;
重组模块,用于若所述第一队列中的目标类报文的数量与所述目标类报文对应的分片数相同,则将所述第一队列中的所有目标类报文转存入第二队列中进行重组,以得到完整报文。
10.一种电子设备,其特征在于,包括:处理器、存储器,所述存储器存储有所述处理器可执行的机器可读指令,当电子设备运行时,所述机器可读指令被所述处理器执行时执行如权利要求1至8任一所述的方法的步骤。
11.一种计算机可读存储介质,其特征在于,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行如权利要求1至8任一所述的方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111392822.5A CN114070801A (zh) | 2021-11-23 | 2021-11-23 | 报文处理方法、报文传输方法、装置及电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111392822.5A CN114070801A (zh) | 2021-11-23 | 2021-11-23 | 报文处理方法、报文传输方法、装置及电子设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114070801A true CN114070801A (zh) | 2022-02-18 |
Family
ID=80279236
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111392822.5A Pending CN114070801A (zh) | 2021-11-23 | 2021-11-23 | 报文处理方法、报文传输方法、装置及电子设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114070801A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115134171A (zh) * | 2022-08-30 | 2022-09-30 | 湖南麒麟信安科技股份有限公司 | 隔离网络环境下加密存储报文的方法、装置、系统及介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110958331A (zh) * | 2019-12-27 | 2020-04-03 | 视联动力信息技术股份有限公司 | 一种数据传输方法及终端 |
CN111355672A (zh) * | 2020-03-02 | 2020-06-30 | 杭州迪普信息技术有限公司 | 一种报文转发的方法及装置 |
CN111786905A (zh) * | 2020-06-30 | 2020-10-16 | 北京天融信网络安全技术有限公司 | 报文重组方法及装置、处理器、存储介质及网络设备 |
-
2021
- 2021-11-23 CN CN202111392822.5A patent/CN114070801A/zh active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110958331A (zh) * | 2019-12-27 | 2020-04-03 | 视联动力信息技术股份有限公司 | 一种数据传输方法及终端 |
CN111355672A (zh) * | 2020-03-02 | 2020-06-30 | 杭州迪普信息技术有限公司 | 一种报文转发的方法及装置 |
CN111786905A (zh) * | 2020-06-30 | 2020-10-16 | 北京天融信网络安全技术有限公司 | 报文重组方法及装置、处理器、存储介质及网络设备 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115134171A (zh) * | 2022-08-30 | 2022-09-30 | 湖南麒麟信安科技股份有限公司 | 隔离网络环境下加密存储报文的方法、装置、系统及介质 |
CN115134171B (zh) * | 2022-08-30 | 2022-11-29 | 湖南麒麟信安科技股份有限公司 | 隔离网络环境下加密存储报文的方法、装置、系统及介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8166547B2 (en) | Method, apparatus, signals, and medium for managing a transfer of data in a data network | |
CN111555963B (zh) | 消息推送方法、装置、电子设备及存储介质 | |
US20070160062A1 (en) | Systems And Methods For Improved Network Based Content Inspection | |
CN110740144B (zh) | 确定攻击目标的方法、装置、设备及存储介质 | |
CN109257143A (zh) | 用于有长度限制的网络传输协议中分片传输数据包的方法 | |
WO2019192133A1 (zh) | 电子装置、数据链路风险预警方法及存储介质 | |
US7515585B2 (en) | Data communication optimization | |
KR101809365B1 (ko) | M2M/IoT 플랫폼에서 MQTT 프로토콜을 활용한 메시지 단편화 방법 | |
US7283527B2 (en) | Apparatus and method of maintaining two-byte IP identification fields in IP headers | |
CN108683606B (zh) | IPsec防重放的方法、装置、网络设备及可读存储介质 | |
CN114070801A (zh) | 报文处理方法、报文传输方法、装置及电子设备 | |
CN113595932A (zh) | 数据乱序报文的处理方法及专用集成电路 | |
US8112488B2 (en) | Methods and computer programs for formulating messaging platform capacity projections | |
CN114785805B (zh) | 一种数据传输方法、装置、电子设备以及存储介质 | |
CN111355793A (zh) | 一种基于HTML5和Python的大文件上传方法 | |
CN113055493B (zh) | 数据包处理方法、装置、系统、调度设备和存储介质 | |
CN109739660B (zh) | 异常消息处理方法及装置 | |
CN102891732A (zh) | 数据发送方法和装置以及数据接收方法和装置 | |
CN116634587B (zh) | 一种数据恢复的方法、装置以及存储介质 | |
CN113438506B (zh) | 视频文件的还原方法、装置、计算机设备和存储介质 | |
CN115134275B (zh) | 利用IPv6逐跳扩展头实现单向网络测试的方法、电子设备及存储介质 | |
CN110071868B (zh) | 一种链路聚合方法、装置及网络设备 | |
CN117061072B (zh) | 报文传输方法、装置、设备及存储介质 | |
CN114301960B (zh) | 集群非对称流量的处理方法及装置、电子设备及存储介质 | |
JP2004146931A (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 |