CN114448573B - 一种报文处理方法及装置 - Google Patents
一种报文处理方法及装置 Download PDFInfo
- Publication number
- CN114448573B CN114448573B CN202210197431.6A CN202210197431A CN114448573B CN 114448573 B CN114448573 B CN 114448573B CN 202210197431 A CN202210197431 A CN 202210197431A CN 114448573 B CN114448573 B CN 114448573B
- Authority
- CN
- China
- Prior art keywords
- message
- message group
- service processing
- messages
- processing
- 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
- 238000003672 processing method Methods 0.000 title abstract description 16
- 238000012545 processing Methods 0.000 claims abstract description 316
- 238000000034 method Methods 0.000 claims abstract description 45
- 230000005540 biological transmission Effects 0.000 claims description 10
- 238000004590 computer program Methods 0.000 claims description 10
- 238000012790 confirmation Methods 0.000 claims description 3
- 238000010586 diagram Methods 0.000 description 4
- 238000003491 array Methods 0.000 description 1
- 230000001174 ascending effect Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000004321 preservation Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/0078—Avoidance of errors by organising the transmitted data in a format specifically designed to deal with errors, e.g. location
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本申请实施例提供了一种报文处理方法及装置,涉及通信技术领域,该方法包括:按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理;若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理;针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文;满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。如此,能够在一定程度上避免网络业务出错。
Description
技术领域
本申请涉及通信技术领域,特别是涉及一种报文处理方法及装置。
背景技术
随着因特网的带宽的速率越来越高,网络设备(例如,网络处理器(NetworkProcessor,NP))对报文处理速度的需求也日益提高。为了适应这种需求,网络处理器中通常可以设置有多内核的CPU,通过多个内核对接收到的报文进行业务处理,并在完成业务处理后转发至下游设备。
由于每个内核对报文进行处理的速度不同,若在每一报文完成业务处理后,网络处理器则将该报文发送至下游设备,可能会导致下游设备接收到的报文的顺序,与网络处理器接收到的报文的顺序不一致,进而,会导致业务出错。
发明内容
本申请实施例的目的在于提供一种报文处理方法及装置,能够在一定程度上避免业务出错。具体技术方案如下:
第一方面,为了达到上述目的,本申请实施例公开了一种报文处理方法,所述方法包括:
按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理;
若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理;其中,每一报文组包含多个接收顺序相邻的报文,该报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻;
针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文;其中,满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。
可选的,所述针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文,包括:
针对每一报文组,在该报文组对应的指定时刻向后延伸预设超时时长内,当确认该报文组中的所有报文均已完成业务处理时,按照接收顺序发送该报文组中的所有报文。
可选的,所述针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文,包括:
针对每一报文组,在已对前一报文组中的报文进行发送处理,且满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文。
可选的,所述方法还包括:
针对每一报文组,当到达该报文组对应的指定时刻向后延伸预设超时时长的时刻时,丢弃该报文组中未完成业务处理的报文。
可选的,所述方法还包括:
记录该报文组中丢弃的报文的统计信息,其中,所述统计信息用于确定报文的丢弃原因。
可选的,已接收到的每一报文具有对应的业务处理状态;所述业务处理状态表示未进行业务处理、正在进行业务处理,或者已完成业务处理;
所述按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理,包括:
根据已接收到的报文的业务处理状态,确认未进行业务处理的目标报文;
当按照接收顺序对所述目标报文进行业务处理时,将所述目标报文的业务处理状态标记为用于表征正在进行业务处理的状态;
在所述确认该目标报文已完成业务处理之后,所述方法还包括:
将该目标报文的业务处理状态标记为用于表征已完成业务处理的状态;
所述针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文,包括:
针对每一报文组,在满足该报文组对应的发送条件时,根据该报文组中报文的业务处理状态,按照接收顺序发送该报文组中已完成业务处理的报文。
第二方面,为了达到上述目的,本申请实施例公开了一种报文处理装置,所述装置包括:
业务处理模块,用于按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理;
状态确认模块,用于若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理;其中,每一报文组包含多个接收顺序相邻的报文,该报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻;
报文发送模块,用于针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文;其中,满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。
可选的,所述报文发送模块,具体用于针对每一报文组,在该报文组对应的指定时刻向后延伸预设超时时长内,当确认该报文组中的所有报文均已完成业务处理时,按照接收顺序发送该报文组中的所有报文。
可选的,所述报文发送模块,具体用于针对每一报文组,在已对前一报文组中的报文进行发送处理,且满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文。
可选的,所述装置还包括:
报文丢弃模块,用于针对每一报文组,当到达该报文组对应的指定时刻向后延伸预设超时时长的时刻时,丢弃该报文组中未完成业务处理的报文。
可选的,所述装置还包括:
统计信息记录模块,用于记录该报文组中丢弃的报文的统计信息,其中,所述统计信息用于确定报文的丢弃原因。
可选的,已接收到的每一报文具有对应的业务处理状态;所述业务处理状态表示未进行业务处理、正在进行业务处理,或者已完成业务处理;
所述业务处理模块,具体用于根据已接收到的报文的业务处理状态,确认未进行业务处理的目标报文;
当按照接收顺序对所述目标报文进行业务处理时,将所述目标报文的业务处理状态标记为用于表征正在进行业务处理的状态;
所述装置还包括:
状态标记模块,用于在所述确认该目标报文已完成业务处理之后,将该目标报文的业务处理状态标记为用于表征已完成业务处理的状态;
所述报文发送模块,具体用于针对每一报文组,在满足该报文组对应的发送条件时,根据该报文组中报文的业务处理状态,按照接收顺序发送该报文组中已完成业务处理的报文。
在本申请实施的另一方面,为了达到上述目的,本申请实施例还公开了一种处理芯片,所述处理芯片用于执行上述任一所述的报文处理方法。
在本申请实施的又一方面,还提供了一种计算机可读存储介质,所述计算机可读存储介质内存储有计算机程序,所述计算机程序被处理芯片执行时实现如上述任一所述的报文处理方法。
本申请实施例还提供了一种包含指令的计算机程序产品,当其在处理芯片上运行时,使得处理芯片执行上述任一所述的报文处理方法。
本申请实施例有益效果:
本申请实施例提供的报文处理方法,按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理;若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理;其中,每一报文组包含多个接收顺序相邻的报文,该报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻;针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文;其中,满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。
基于上述处理,针对每一报文组,由于其中的报文是按照接收顺序进行发送,也就使得该报文组中的报文的发送顺序与接收顺序一致,进而,能够在一定程度上避免网络业务出错。另外,由于每一报文组包含多个接收顺序相邻的报文,且按照接收顺序对报文进行业务处理。也就是说,各报文组之间的处理顺序也是根据包含的报文的接收顺序确定的,也就在一定程度上使得前一个报文组中的报文在后一个报文组中的报文之前完成业务处理,能够在一定程度上保证前一个报文组中的报文在后一个报文组中的报文之前完成发送处理,保证报文组之间按照接收顺序进行发送处理,以进一步避免网络业务出错。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,还可以根据这些附图获得其他的实施例。
图1为本申请实施例提供的一种报文处理方法的流程图;
图2为本申请实施例提供的另一种报文处理方法的流程图;
图3为本申请实施例提供的另一种报文处理方法的流程图;
图4为本申请实施例提供的另一种报文处理方法的流程图;
图5为本申请实施例提供的另一种报文处理方法的流程图;
图6为本申请实施例提供的一种报文处理的原理示意图;
图7为本申请实施例提供的一种报文处理的流程图;
图8为本申请实施例提供的一种报文处理装置的结构图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员基于本申请所获得的所有其他实施例,都属于本申请保护的范围。
现有技术中,由于网络处理器中的每个内核对报文进行业务处理的速度不同。若在每一报文完成业务处理后,网络处理器则将该报文发送至下游设备,可能会导致下游设备接收到的报文的顺序,与网络处理器接收到的报文的顺序不一致,进而,会导致网络业务出错。
为了解决上述问题,本申请提供了一种报文处理方法,该报文处理方法可以应用于处理芯片,该处理芯片可以为网络处理器芯片,例如,该处理芯片可以为路由器中的处理芯片,或者,也可以为交换机中的处理芯片,但并不限于此。
参见图1,图1为本申请实施例提供了一种报文处理方法的流程图,该方法包括以下步骤:
S101:按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理。
S102:若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理。
其中,每一报文组包含多个接收顺序相邻的报文,该报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻。
S103:针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文。
其中,满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。
本申请实施例提供的报文处理方法,针对每一报文组,由于其中的报文是按照接收顺序进行发送,也就使得该报文组中的报文的发送顺序与接收顺序一致,进而,能够在一定程度上避免网络业务出错。另外,由于每一报文组包含多个接收顺序相邻的报文,且按照接收顺序对报文进行业务处理。也就是说,各报文组之间的处理顺序也是根据包含的报文的接收顺序确定的,也就在一定程度上使得前一个报文组中的报文在后一个报文组中的报文之前完成业务处理,能够在一定程度上保证前一个报文组中的报文在后一个报文组中的报文之前完成发送处理,保证报文组之间按照接收顺序进行发送处理,以进一步避免网络业务出错。
一种实现方式中,针对接收到的每一报文,处理芯片可以按照该报文的接收顺序设置该报文的序号。即,各报文的序号为按照接收顺序依次递增的。例如,针对接收到的每一报文,处理芯片可以在该报文中添加一个字段,用于表示该报文的序号;或者,处理芯片也可以记录该报文与该报文的序号的对应关系。
一种实现方式中,处理芯片可以将接收到的报文存储至预设的缓存空间,该处理芯片中的内核能够加载缓存空间中存储的报文,以进行业务处理。例如,当处理芯片接收到一个报文时,可以为该报文添加序号,并将已添加序号的该报文存储至缓存空间。
各报文组包含的报文的数目可以相同,也可以不同。一种实现方式中,一个报文组包含的报文的数目(本申请实施例中可以称为保序深度),可以由技术人员根据经验进行设置。例如,每一报文组包含的报文的数目可以为5,或者,也可以为4,但并不限于此。相应的,处理芯片可以根据报文的序号,以及保序深度,对接收到的报文进行分组。
例如,若各报文组包含的报文的数目相同,且保序深度为5,则处理芯片可以按照接收顺序,将接收到的每5个报文划分为一个报文组。
本申请实施例中提到的业务处理可以根据当前的业务场景确定,例如,对报文进行业务处理可以为统计报文的报文信息(例如,目的IP地址、源IP地址等信息),或者,也可以为修改报文的报文信息,但并不限于此。
一种实现方式中,处理芯片可以通过内核,确定缓存空间中当前未进行业务处理的报文,并按照各自序号的递增顺序对确定出的报文进行业务处理。
在一个实施例中,已接收到的每一报文具有对应的业务处理状态;业务处理状态表示未进行业务处理、正在进行业务处理,或者已完成业务处理。
相应的,参见图2,在图1的基础上,上述步骤S101可以包括以下步骤:
S1011:根据已接收到的报文的业务处理状态,确认未进行业务处理的目标报文。
S1012:当按照接收顺序对目标报文进行业务处理时,将目标报文的业务处理状态标记为用于表征正在进行业务处理的状态。
在上述步骤S102之后,该方法还可以包括以下步骤:
S104:将该目标报文的业务处理状态标记为用于表征已完成业务处理的状态。
上述步骤S103可以包括以下步骤:
S1031:针对每一报文组,在满足该报文组对应的发送条件时,根据该报文组中报文的业务处理状态,按照接收顺序发送该报文组中已完成业务处理的报文。
在本申请实施例中,处理芯片可以记录接收到的每一个报文的业务处理状态。
一种实现方式中,针对接收到的每一报文,在未对该报文进行业务处理时,处理芯片可以在该报文中添加一个表示该报文当前未进行业务处理的字段。后续,处理芯片可以根据对该报文进行业务处理的过程,对该报文中的该字段进行更新,以更新该报文的业务处理状态。
本申请实施例中的指定时刻是与报文组对应的。一个报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻,由于按照接收顺序对接收的报文进行业务处理,因此,该指定时刻为开始对该报文组中最先接收到的报文进行业务处理的时刻。若处理芯片按照接收顺序对接收到的每一报文设置序号,则一个报文组中最先接收到的报文为该报文组中序号最小的报文,也就是说,该报文组对应的指定时刻为开始对该报文组中序号最小的报文进行业务处理的时刻。
在一个实施例中,处理芯片可以包含多个内核,通过每一内核可以开启至少一个线程,用于对报文进行业务处理。因此,处理芯片可以采用多线程并行的方式对报文进行业务处理。由于一个报文组对应一个指定时刻,因此,各报文组对应的指定时刻可能相同,也可能不同。
预设超时时长与报文组对应,即,一个报文组对应一个预设超时时长。例如,一个报文组对应的预设超时时长可以根据该报文组中的报文的数目确定。该报文组中的报文的数目越大,则该报文组对应的预设超时时长越长,反之,则该报文组对应的预设超时时长越短。由于各报文组包含的报文的数目可以相同,也可以不同,因此,各报文组对应的预设超时时长可以相同,也可以不同。
在本申请实施例中,一个报文组对应的指定时刻向后延伸预设超时时长的时刻,可以称为该报文组对应的终止时刻。
针对上述步骤S103,处理芯片可以通过以下至少两种方式实现:
方式一:在一个实施例中,参见图3,在图1的基础上,上述步骤S103可以包括以下步骤:
S1032:针对每一报文组,在该报文组对应的指定时刻向后延伸预设超时时长内,当确认该报文组中的所有报文均已完成业务处理时,按照接收顺序发送该报文组中的所有报文。
一种实现方式中,针对每一报文组,处理芯片可以在该报文组对应的指定时刻后的预设超时时长内,对该报文组中各报文的业务处理状态进行检测(例如,周期性检测),以确定该报文组中的所有报文是否完成业务处理。
可以理解的是,在对应的指定时刻后的预设超时时长内,当检测到该报文组中的所有报文均完成业务处理时,处理芯片可以按照接收顺序发送该报文组中完成业务处理的报文,即,按照接收顺序发送该报文组中的所有报文,而无需等待至终止时刻。进而,能够及时发送该报文组中的报文,降低下游设备的等待时长,提高报文的处理效率。
针对方式一,当达到终止时刻时,如果该报文组中并非所有报文均完成业务处理,此时,处理芯片可以按照接收顺序发送该报文组中已完成业务处理的报文(即该报文组中的部分报文)。当达到终止时刻时,如果该报文组中所有报文均完成业务处理,此时,按照接收顺序发送的是该报文组中的所有报文。
在一个实施例中,在对应的指定时刻后的预设超时时长内,当检测到该报文组中的所有报文均完成业务处理时,若此时仍未达到对应的终止时刻,则处理芯片可以在该时刻与终止时刻之间的任一时刻,按照接收顺序发送该报文组中的所有报文。
方式二:在一个实施例中,参见图4,在图1的基础上,上述步骤S103可以包括以下步骤:
S1033:针对每一报文组,当到达该报文组对应的指定时刻向后延伸预设超时时长的时刻时,按照接收顺序发送该报文组中完成业务处理的报文。
一种实现方式中,在到达终止时刻时,处理芯片可以确定该报文组中完成业务处理的报文,并进行发送。例如,在该报文组对应的指定时刻,处理芯片可以开启计时器进行计时,当计时时长达到预设超时时长时,处理芯片可以确定该报文组中完成业务处理的报文。
基于上述处理,在指定时刻向后延伸预设超时时长内,处理芯片无需频繁多次检测该报文组中报文的业务处理状态,能够减少处理芯片的数据处理量,降低业务压力。
在一个实施例中,参见图5,在图1的基础上,上述步骤S103可以包括以下步骤:
S1034:针对每一报文组,在已对前一报文组中的报文进行发送处理,且满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文。
在一个实施例中,由于处理芯片对不同的报文进行业务处理所消耗的时间不同,且各报文组对应的指定时刻可能相同。
因此,若处理芯片基于上述方式一发送报文,则针对某一报文组(可以称为当前报文组),当检测到该当前报文组中的所有报文均完成业务处理时,此时,若未达到前一报文组对应的终止时刻,且前一报文组中存在未完成业务处理的报文。即,此时,处理芯片并未对前一报文组中的报文进行发送处理。如果处理芯片此时发送该当前报文组中的报文,则会导致业务出错。为了避免上述情况,则处理芯片可以在已对前一报文组中的报文进行发送处理的情况下(即已达到前一报文组对应的终止时刻,或者,前一报文组中的所有报文在对应的指定时刻后的预设超时时长内已完成业务处理),发送该当前报文组中的报文。
若处理芯片基于上述方式二发送报文,则针对某一报文组(可以称为当前报文组),当达到该当前报文组对应的终止时刻时,此时,若未达到前一报文组对应的终止时刻,即,此时,处理芯片并未对前一报文组中的报文进行发送处理。如果处理芯片此时发送该当前报文组中的报文,则会导致业务出错。为了避免上述情况,则处理芯片可以在已对前一报文组中的报文进行发送处理的情况下(即已达到前一报文组对应的终止时刻),发送该当前报文组中的报文。
基于上述处理,能够进一步避免业务出错。
在一个实施例中,该方法还包括:
针对每一报文组,当到达该报文组对应的指定时刻向后延伸预设超时时长的时刻时,丢弃该报文组中未完成业务处理的报文。
一种实现方式中,当达到一个报文组对应的终止时刻时,如果该报文组中存在未完成业务处理的报文,则处理芯片可以丢弃该报文组中未完成业务处理的报文。例如,将该报文组中未完成业务处理的报文从缓存空间中删除,以避免存储空间被无效占用。
在一个实施例中,该方法还包括:记录每一报文组中丢弃的报文的统计信息。
其中,统计信息用于确定报文的丢弃原因。
在本申请实施例中,针对丢弃的报文,可以统计其数目,或者,也可以记录丢弃的每一报文的报文信息,但并不限于此。如此,可以通过记录的信息分析报文丢弃的原因,实现业务错误的溯源。
本申请实施例提供的报文处理方法可以通过软件来实现,能够避免对处理芯片所属的电子设备的硬件进行改进而导致的后端设备重新布线的问题情况。
参见图6,图6为本申请实施例提供的一种报文处理的原理示意图。
图6中,报文n至报文n+5,分别表示处理芯片按照顺序接收到的报文的序号。图6中,未填充的矩形表示未进行业务处理的报文,填充有斜线的矩形表示正在进行业务处理的报文,填充有竖线的矩形表示已完成业务处理的报文。
在T=1时刻,处理芯片已接收到报文n,报文n+1,报文n+2,报文n+3,报文n+4,以及报文n+5,并存储至缓存空间。若保序深度为4,则处理芯片可以确定报文n至报文n+3属于一个报文组(可以称为第一报文组),报文n+4和报文n+5属于后一个报文组。此时,处理芯片未对报文n至报文n+5进行业务处理。在T=2时刻,处理芯片已开始对报文n至报文n+3进行业务处理,此时,仍未达到第一报文组对应的终止时刻。在T=3时刻,报文n,报文n+1和报文n+3报文已完成业务处理,报文n+2未完成业务处理。若T=3时刻为第一报文组对应的终止时刻,则处理芯片可以按照接收顺序发送第一报文组中完成业务处理的报文,也就是说,处理芯片可以先发送报文n,再发送报文n+1,然后发送报文n+3,并丢弃报文n+2。
若T=3时刻仍未达到第一报文组对应的终止时刻,且处理芯片基于上述方式一发送报文,则在达到第一报文组对应的终止时刻之前,处理芯片可以等待,直至报文n+2完成业务处理。相应的,若在达到第一报文组对应的终止时刻之前,报文n+2完成业务处理,则处理芯片可以按照接收顺序,依次发送报文n、报文n+1、报文n+2、报文n+3;若在达到第一报文组对应的终止时刻时,报文n+2仍未完成业务处理,则处理芯片可以按照接收顺序,依次发送报文n、报文n+1、报文n+3,并丢弃报文n+2。
若T=3时刻仍未达到第一报文组对应的终止时刻,且处理芯片基于上述方式二发送报文,在达到第一报文组对应的终止时刻时,处理芯片可以直接发送第一报文组中完成业务处理的报文。可以理解的是,若达到该终止时刻时,报文n+2完成业务处理,则处理芯片按照接收顺序依次发送报文n、报文n+1、报文n+2、报文n+3。反之,若达到该终止时刻时,报文n+2仍未完成业务处理,则处理芯片按照顺序发送报文n、报文n+1、报文n+3,并丢弃报文n+2。
图7为本申请实施例提供的一种报文处理的流程图。
图7中,处理芯片可以获取预设的保序深度以及预设超时时长。处理芯片可以对接收到的报文进行报文缓存,即,将接收到的报文存储至缓存空间,然后,对缓存空间中的报文进行业务处理,即,处理芯片可以按照接收顺序,对缓存空间中的报文进行业务处理。
针对每一报文,处理芯片可以标记该报文的业务处理状态。报文返回缓存空间,即,当某一报文完成业务处理时,处理芯片可以标记该报文为已完成业务处理。
针对每一报文组,处理芯片可以判断该报文组中的报文是否在对应的终止时刻之前均完成业务处理。
若否,则丢弃未完成业务处理的报文,即,在达到该报文组对应的终止时刻时,丢弃该报文组中未完成业务处理的报文。
若是,则按照接收顺序发送该报文组中完成业务处理的报文,发送报文的方式可以为上述方式一,也可以为上述方式二。
然后,处理芯片可以进行下一轮处理,即,处理芯片按照相同的方式对后一报文组进行处理。
基于相同的发明构思,本申请实施例还提供了一种报文处理装置,参见图8,图8为本申请实施例提供的一种报文处理装置的结构图,包括:
业务处理模块801,用于按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理;
状态确认模块802,用于若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理;其中,每一报文组包含多个接收顺序相邻的报文,该报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻;
报文发送模块803,用于针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文;其中,满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。
可选的,所述报文发送模块803,具体用于针对每一报文组,在该报文组对应的指定时刻向后延伸预设超时时长内,当确认该报文组中的所有报文均已完成业务处理时,按照接收顺序发送该报文组中的所有报文。
可选的,所述报文发送模块803,具体用于针对每一报文组,在已对前一报文组中的报文进行发送处理,且满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文。
可选的,所述装置还包括:
报文丢弃模块,用于针对每一报文组,当到达该报文组对应的指定时刻向后延伸预设超时时长的时刻时,丢弃该报文组中未完成业务处理的报文。
可选的,所述装置还包括:
统计信息记录模块,用于记录该报文组中丢弃的报文的统计信息,其中,所述统计信息用于确定报文的丢弃原因。
可选的,已接收到的每一报文具有对应的业务处理状态;所述业务处理状态表示未进行业务处理、正在进行业务处理,或者已完成业务处理;
所述业务处理模块801,具体用于根据已接收到的报文的业务处理状态,确认未进行业务处理的目标报文;
当按照接收顺序对所述目标报文进行业务处理时,将所述目标报文的业务处理状态标记为用于表征正在进行业务处理的状态;
所述装置还包括:
状态标记模块,用于在所述确认该目标报文已完成业务处理之后,将该目标报文的业务处理状态标记为用于表征已完成业务处理的状态;
所述报文发送模块803,具体用于针对每一报文组,在满足该报文组对应的发送条件时,根据该报文组中报文的业务处理状态,按照接收顺序发送该报文组中已完成业务处理的报文。
本申请实施例还提供了一种处理芯片,处理芯片用于执行上述任一所述的报文处理方法。
上述的处理芯片可以是通用处理器,包括中央处理器(Central ProcessingUnit,CPU)、网络处理器(Network Processor,NP)等;还可以是数字信号处理器(DigitalSignal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。
在本申请提供的又一实施例中,还提供了一种计算机可读存储介质,该计算机可读存储介质内存储有计算机程序,所述计算机程序被处理芯片执行时实现上述任一报文处理的步骤。
在本申请提供的又一实施例中,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得处理芯片执行上述实施例中任一报文处理方法。
在上述实施例中,可以全部或部分地通过软件、硬件、固件或者其任意组合来实现。当使用软件实现时,可以全部或部分地以计算机程序产品的形式实现。所述计算机程序产品包括一个或多个计算机指令。在计算机上加载和执行所述计算机程序指令时,全部或部分地产生按照本申请实施例所述的流程或功能。所述计算机可以是通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一个计算机可读存储介质传输,例如,所述计算机指令可以从一个网站站点、计算机、服务器或数据中心通过有线(例如同轴电缆、光纤、数字用户线(DSL))或无线(例如红外、无线、微波等)方式向另一个网站站点、计算机、服务器或数据中心进行传输。所述计算机可读存储介质可以是计算机能够存取的任何可用介质或者是包含一个或多个可用介质集成的服务器、数据中心等数据存储设备。所述可用介质可以是磁性介质,(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质(例如固态硬盘Solid State Disk(SSD))等。
需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
本说明书中的各个实施例均采用相关的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于装置、处理芯片、计算机可读存储介质以及计算机程序产品实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
以上所述仅为本申请的较佳实施例,并非用于限定本申请的保护范围。凡在本申请的精神和原则之内所作的任何修改、等同替换、改进等,均包含在本申请的保护范围内。
Claims (12)
1.一种报文处理方法,其特征在于,所述方法包括:
按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理;
若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理;其中,每一报文组包含多个接收顺序相邻的报文,该报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻;
针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文;其中,满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。
2.根据权利要求1所述的方法,其特征在于,所述针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文,包括:
针对每一报文组,在已对前一报文组中的报文进行发送处理,且满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
针对每一报文组,当到达该报文组对应的指定时刻向后延伸预设超时时长的时刻时,丢弃该报文组中未完成业务处理的报文。
4.根据权利要求3所述的方法,其特征在于,所述方法还包括:
记录该报文组中丢弃的报文的统计信息,其中,所述统计信息用于确定报文的丢弃原因。
5.根据权利要求1所述的方法,其特征在于,已接收到的每一报文具有对应的业务处理状态;所述业务处理状态表示未进行业务处理、正在进行业务处理,或者已完成业务处理;
所述按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理,包括:
根据已接收到的报文的业务处理状态,确认未进行业务处理的目标报文;
当按照接收顺序对所述目标报文进行业务处理时,将所述目标报文的业务处理状态标记为用于表征正在进行业务处理的状态;
在所述确认该目标报文已完成业务处理之后,所述方法还包括:
将该目标报文的业务处理状态标记为用于表征已完成业务处理的状态;
所述针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文,包括:
针对每一报文组,在满足该报文组对应的发送条件时,根据该报文组中报文的业务处理状态,按照接收顺序发送该报文组中已完成业务处理的报文。
6.一种报文处理装置,其特征在于,所述装置包括:
业务处理模块,用于按照接收顺序,对已接收的报文中未处理的目标报文进行业务处理;
状态确认模块,用于若未处理的目标报文在所属的报文组对应的指定时刻后的预设超时时长内完成了业务处理,则确认该目标报文已完成业务处理;其中,每一报文组包含多个接收顺序相邻的报文,该报文组对应的指定时刻为开始对该报文组中的报文进行业务处理的时刻;
报文发送模块,用于针对每一报文组,在满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文;其中,满足该报文组对应的发送条件包括:在该报文组对应的指定时刻向后延伸预设超时时长内,确认该报文组中的所有报文均已完成业务处理;或者,该报文组对应的指定时刻向后延伸预设超时时长的时刻已到达。
7.根据权利要求6所述的装置,其特征在于,所述报文发送模块,具体用于针对每一报文组,在已对前一报文组中的报文进行发送处理,且满足该报文组对应的发送条件时,按照接收顺序发送该报文组中已完成业务处理的报文。
8.根据权利要求6所述的装置,其特征在于,所述装置还包括:
报文丢弃模块,用于针对每一报文组,当到达该报文组对应的指定时刻向后延伸预设超时时长的时刻时,丢弃该报文组中未完成业务处理的报文。
9.根据权利要求8所述的装置,其特征在于,所述装置还包括:
统计信息记录模块,用于记录该报文组中丢弃的报文的统计信息,其中,所述统计信息用于确定报文的丢弃原因。
10.根据权利要求6所述的装置,其特征在于,已接收到的每一报文具有对应的业务处理状态;所述业务处理状态表示未进行业务处理、正在进行业务处理,或者已完成业务处理;
所述业务处理模块,具体用于根据已接收到的报文的业务处理状态,确认未进行业务处理的目标报文;
当按照接收顺序对所述目标报文进行业务处理时,将所述目标报文的业务处理状态标记为用于表征正在进行业务处理的状态;
所述装置还包括:
状态标记模块,用于在所述确认该目标报文已完成业务处理之后,将该目标报文的业务处理状态标记为用于表征已完成业务处理的状态;
所述报文发送模块,具体用于针对每一报文组,在满足该报文组对应的发送条件时,根据该报文组中报文的业务处理状态,按照接收顺序发送该报文组中已完成业务处理的报文。
11.一种处理芯片,其特征在于,所述处理芯片用于执行权利要求1-5任一所述的方法步骤。
12.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质内存储有计算机程序,所述计算机程序被处理芯片执行时实现权利要求1-5任一所述的方法步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210197431.6A CN114448573B (zh) | 2022-03-02 | 2022-03-02 | 一种报文处理方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210197431.6A CN114448573B (zh) | 2022-03-02 | 2022-03-02 | 一种报文处理方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114448573A CN114448573A (zh) | 2022-05-06 |
CN114448573B true CN114448573B (zh) | 2024-02-23 |
Family
ID=81359432
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210197431.6A Active CN114448573B (zh) | 2022-03-02 | 2022-03-02 | 一种报文处理方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114448573B (zh) |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1996958A (zh) * | 2006-12-30 | 2007-07-11 | 华为技术有限公司 | 保证报文顺序的方法和装置 |
CN102055649A (zh) * | 2009-10-29 | 2011-05-11 | 成都市华为赛门铁克科技有限公司 | 多核系统的报文处理方法、装置及系统 |
CN102204183A (zh) * | 2011-05-09 | 2011-09-28 | 华为技术有限公司 | 报文保序处理方法、保序协处理器和网络设备 |
CN102694631A (zh) * | 2012-05-23 | 2012-09-26 | 华为技术有限公司 | 一种用于控制数据传输的方法和装置 |
WO2017161999A1 (zh) * | 2016-03-22 | 2017-09-28 | 华为技术有限公司 | 一种报文处理的方法及相关设备 |
CN111817985A (zh) * | 2019-04-10 | 2020-10-23 | 华为技术有限公司 | 业务处理方法及装置 |
CN112948298A (zh) * | 2021-04-15 | 2021-06-11 | 新华三信息安全技术有限公司 | 一种报文处理方法及装置 |
WO2021159478A1 (zh) * | 2020-02-14 | 2021-08-19 | 华为技术有限公司 | 报文保序方法和装置 |
CN113691631A (zh) * | 2021-08-27 | 2021-11-23 | 绿盟科技集团股份有限公司 | 一种数据清理的方法、装置及电子设备 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113014528B (zh) * | 2019-12-19 | 2022-12-09 | 厦门网宿有限公司 | 报文处理方法、处理单元及虚拟专用网络服务器 |
-
2022
- 2022-03-02 CN CN202210197431.6A patent/CN114448573B/zh active Active
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1996958A (zh) * | 2006-12-30 | 2007-07-11 | 华为技术有限公司 | 保证报文顺序的方法和装置 |
CN102055649A (zh) * | 2009-10-29 | 2011-05-11 | 成都市华为赛门铁克科技有限公司 | 多核系统的报文处理方法、装置及系统 |
CN102204183A (zh) * | 2011-05-09 | 2011-09-28 | 华为技术有限公司 | 报文保序处理方法、保序协处理器和网络设备 |
CN102694631A (zh) * | 2012-05-23 | 2012-09-26 | 华为技术有限公司 | 一种用于控制数据传输的方法和装置 |
WO2017161999A1 (zh) * | 2016-03-22 | 2017-09-28 | 华为技术有限公司 | 一种报文处理的方法及相关设备 |
CN111817985A (zh) * | 2019-04-10 | 2020-10-23 | 华为技术有限公司 | 业务处理方法及装置 |
WO2021159478A1 (zh) * | 2020-02-14 | 2021-08-19 | 华为技术有限公司 | 报文保序方法和装置 |
CN112948298A (zh) * | 2021-04-15 | 2021-06-11 | 新华三信息安全技术有限公司 | 一种报文处理方法及装置 |
CN113691631A (zh) * | 2021-08-27 | 2021-11-23 | 绿盟科技集团股份有限公司 | 一种数据清理的方法、装置及电子设备 |
Non-Patent Citations (2)
Title |
---|
On Packet Reordering in Time-Sensitive Networks;Ehsan Mohammadpour;《IEEE/ACM Transactions on Networking》;全文 * |
一种基于数据平面可编程的软件定义网络报文转发验证机制;左志斌;常朝稳;祝现威;;电子与信息学报(第05期);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN114448573A (zh) | 2022-05-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US12075106B2 (en) | Message sending method and device, readable medium and electronic device | |
CN108390856B (zh) | 一种DDoS攻击检测方法、装置及电子设备 | |
US11979761B2 (en) | Method and apparatus for detecting time series data | |
CN111314217B (zh) | 一种多链路传输系统 | |
CN108023941B (zh) | 语音控制方法及装置和电子设备 | |
CN109150741B (zh) | 报文发送方法、装置、电子设备及存储介质 | |
US9935861B2 (en) | Method, system and apparatus for detecting instant message spam | |
CN107770092A (zh) | 一种数据传输方法、装置、移动终端和存储介质 | |
CN114448573B (zh) | 一种报文处理方法及装置 | |
CN111224756B (zh) | 确定数据传输异常的方法、装置、存储介质及电子设备 | |
CN110309028B (zh) | 监控信息获取方法、服务监控方法、装置及系统 | |
CN112202914B (zh) | 一种消息推送方法及装置 | |
CN111884932B (zh) | 一种链路确定方法、装置、设备和计算机可读存储介质 | |
CN110248138A (zh) | 进行音视频会议的方法和装置 | |
CN110071868B (zh) | 一种链路聚合方法、装置及网络设备 | |
CN114760249A (zh) | 一种基于sdn网络的数据处理方法和装置及设备 | |
CN114428685A (zh) | 一种数据处理的方法、装置、设备及计算机存储介质 | |
CN109347933B (zh) | 一种建立连接的方法和装置 | |
CN105376103A (zh) | 消息计数方法及装置 | |
CN111083067A (zh) | 数据流拼接的方法、装置、存储介质和终端设备 | |
CN117176839B (zh) | 遥测报文传输方法、装置、通信设备及存储介质 | |
CN113438520B (zh) | 数据处理方法、装置及系统 | |
CN113556352B (zh) | 一种信息推送方法、装置、终端设备及存储介质 | |
CN111063092B (zh) | 基于区块链的抽奖方法、装置、电子设备及存储介质 | |
CN113535428B (zh) | 请求消息和响应消息的处理方法、装置、设备和介质 |
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 |