CN107592287A - 一种报文加速方法及装置 - Google Patents
一种报文加速方法及装置 Download PDFInfo
- Publication number
- CN107592287A CN107592287A CN201610530583.8A CN201610530583A CN107592287A CN 107592287 A CN107592287 A CN 107592287A CN 201610530583 A CN201610530583 A CN 201610530583A CN 107592287 A CN107592287 A CN 107592287A
- Authority
- CN
- China
- Prior art keywords
- message
- sent
- software
- hardware
- acceleration rule
- 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
- 238000000034 method Methods 0.000 title claims abstract description 51
- 230000001133 acceleration Effects 0.000 claims abstract description 164
- 238000012545 processing Methods 0.000 claims abstract description 106
- 230000006870 function Effects 0.000 claims description 73
- 238000001514 detection method Methods 0.000 claims description 48
- 238000012986 modification Methods 0.000 claims description 39
- 230000004048 modification Effects 0.000 claims description 39
- 238000010586 diagram Methods 0.000 description 10
- 238000004590 computer program Methods 0.000 description 7
- 238000004458 analytical method Methods 0.000 description 4
- 238000004891 communication Methods 0.000 description 2
- 230000003247 decreasing effect Effects 0.000 description 2
- 238000012217 deletion Methods 0.000 description 2
- 230000037430 deletion Effects 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 239000000203 mixture Substances 0.000 description 2
- 238000013519 translation Methods 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 1
- 230000003139 buffering effect Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/40—Network security protocols
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种报文加速方法,包括:根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与所述硬件加速规则不匹配但与所述软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速;所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。本发明还同时公开了一种报文加速装置。
Description
技术领域
本发明涉及通信领域中的报文处理技术,具体涉及一种报文加速方法及装置。
背景技术
随着网络技术的飞速发展,高清视频、实时通讯等应用对网络的吞吐量、时延和灵活性都提出了更高的挑战,家庭网关作为固网接入的主流设备也正在面临着同样地挑战,因此,对于报文加速的处理已显得必不可少。
现有技术中,家庭网关的报文加速包括:软件加速和硬件加速;其中,所述软件加速,因受限于家庭网关中处理器的处理能力,难以满足当前日益增加的带宽需求;所述硬件加速,因所述硬件加速中专有的芯片只能针对特殊场景或特殊类型的报文进行加速,灵活性较差,并且,硬件加速中的处理器芯片因为成本高,难以大规模普及。
发明内容
为解决现有存在的技术问题,本发明实施例期望提供一种报文加速方法及装置,能够对不同类型的报文进行加速处理。
本发明实施例的技术方案是这样实现的:
根据本发明实施例的一方面,提供一种报文加速方法,所述方法包括:
根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与硬件加速规则不匹配但与软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速;
所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。
上述方案中,所述报文特征与所述软件加速规则不匹配时,所述方法还包括:
发送所述待发送报文到相应的软件功能模块,并检测所述待发送报文是否在所述软件功能模块终结;
所述待发送报文不在所述软件功能模块终结时,获取所述软件功能模块的报文处理动作,并检测经所述软件功能模块处理后的所述待发送报文是否能软件加速;
所述待发送报文能软件加速时,将所述报文特征以及所述软件功能模块的报文处理动作配置到所述软件加速规则,根据所述软件加速规则对所述待发送报文进行处理。
上述方案中,所述待发送报文与所述软件加速规则匹配或所述待发送报文不在所述软件功能模块终结时,所述方法还包括:
获取所述待发送报文的修改编码,根据获取到的所述修改编码对所述待发送报文进行处理。
上述方案中,所述报文特征与所述软件加速规则不匹配时,所述方法还包括:
获取硬件修改指令;
根据获取到的硬件修改指令对所述待发送报文进行处理。
上述方案中,所述待发送报文与所述硬件加速规则不匹配时,所述方法还包括:
申请缓存所述待发送报文,并检测所述申请是否成功;
所述申请已成功时,通过直接存储器访问DMA的方式将所述待发送报文存入主缓存,并对所述待发送报文进行缓存。
上述方案中,所述待发送报文不能硬件加速或不能软件加速时,所述方法还包括:
通过DMA的方式将所述待发送报文从所述主缓存移出,并释放缓存。
根据本发明实施例的另一方面,提供一种报文加速装置,所述装置包括:检测单元和处理单元;其中,
所述检测单元,用于根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与硬件加速规则不匹配但与软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速;
所述处理单元,用于所述检测单元检测到所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。
上述方案中,所述检测单元,还用于所述报文特征与所述软件加速规则不匹配时,发送所述待发送报文到相应的软件功能模块,并检测所述待发送报文是否在所述软件功能模块终结;所述待发送报文不在所述软件功能模块终结时,获取所述软件功能模块的报文处理动作,并检测经所述软件功能模块处理后的所述待发送报文是否能软件加速;
所述处理单元,还用于所述检测单元检测到所述待发送报文能软件加速时,将所述报文特征以及所述软件功能模块的报文处理动作配置到所述软件加速规则,并根据所述软件加速规则对所述待发送报文进行处理。
上述方案中,所述处理单元,还用于所述检测单元检测到所述报文特征与所述软件加速规则匹配,或检测到所述待发送报文不在所述软件功能模块终结时,获取所述待发送报文的修改编码,根据获取到的所述修改编码对所述待发送报文进行处理。
上述方案中,所述处理单元,还用于所述检测单元检测到所述报文特征与所述软件加速规则不匹配时,获取硬件修改指令,根据获取到的所述硬件修改指令对所述待发送报文进行处理。
上述方案中,所述装置还包括:缓存单元;
所述检测单元,还用于检测到所述报文特征与所述硬件加速规则不匹配时,申请缓存所述待发送报文,并检测所述申请是否成功;
所述缓存单元,用于所述检测单元检测到所述申请已成功时,通过DMA的方式将所述待发送报文存入主缓存,并对所述待发送报文进行缓存。
上述方案中,所述缓存单元,还用于所述检测单元检测到所述待发送报文不能硬件加速或不能软件加速时,通过DMA的方式将所述待发送报文从所述主缓存移出,并释放缓存。
本发明实施例提供的一种报文加速方法及装置,根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与硬件加速规则不匹配但与软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速,所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。如此,通过硬件加速方式和软件加速方式的结合对报文进行加速处理,能够实现对不同类型的报文加速;且处理流程简单、方便、灵活,易于推广和普及。
附图说明
图1为本发明实施例一种报文加速方法的流程示意图;
图2为本发明实施例一种报文加速装置的组成结构示意图。
具体实施方式
下面结合附图对本发明的具体实施方式进行详细说明。应当理解的是,此处所描述的具体实施方式仅用于说明和解释本发明,并不用于限制本发明。
图1为本发明实施例一种报文加速方法的流程示意图,如图1所示,该方法包括:
步骤101,根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与硬件加速规则不匹配但与软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速;
这里,所述报文特征通常集中在待发送报文的报文头中的若干个字节内,在硬件接收到待发送报文时,通过将所述待发送报文的报文头中的若干个字节,对照标准报文格式进行分析,根据分析结果得出所述待发送报文的报文特征。例如,依照以太网的标准协议,对所述待发送报文的报文头中的前六个字节进行分析,即对所述待发送报文的目的媒体访问控制/介质访问控制(MAC,Media Access Control/Medium Access Control)地址进行分析,如果分析出所述待发送报文的目的MAC地址为ff:ff:ff:ff:ff:ff,则认为所述待发送报文为广播报文;如果所述待发送报文的目的MAC地址为01:00:5e:xx:xx:xx,则认为了所述待发送报文为组播报文。其中,所述ff:ff:ff:ff:ff:ff和01:00:5e:xx:xx:xx就是所述待发送报文的报文特征。通过所述报文特征能够在所述待发送报文需要软件功能模块处理时,对软件功能模块的分析过程起到加速的作用。
在分析出所述报文特征后,根据分析出的所述报文特征,通过MAC地址学习和查找的方式检测所述待发送报文是否为本地报文,这里所述的本地报文是指局域网内的报文;当检测出所述报文是本发报文时,则通过本地报文交换的方式对所述待发送报文进行加速;当检测到所述待发送报文不是本地报文时,则检测所述报文特征与硬件加速规则是否匹配。
这里,硬件加速规则中包括有至少两个历史报文特征,并且每个报文特征都有与其相匹配的报文处理动作。当硬件检测到所述报文特征与所述硬件加速规则中的其中一个报文特征匹配时,则认为所述报文特征与所述硬件加速规则匹配,这时,硬件可以得到所述硬件加速规则中的报文处理动作,并可以通过所述硬件加速规则中的报文处理动作对所述待发送报文进行硬件加速处理;例如:所述报文特征为:ff:ff:ff:ff:ff:ff,则将所述报文特征ff:ff:ff:ff:ff:ff与硬件加速规则中的所有报文特征进行匹配,若匹配到硬件加速规则中也有报文特征ff:ff:ff:ff:ff:ff,则认为当前报文特征ff:ff:ff:ff:ff:ff与硬件加速规则匹配,可以由硬件加速规则中定义的报文处理动作对当前待发送报文进行加速处理;如果检测到所述硬件加速规则中没有匹配的报文特征ff:ff:ff:ff:ff:ff时,则认为所述报文特征与所述硬件加速规则不匹配,这时,硬件无法得知所述待发送报文的报文处理动作,不能通过所述硬件加速规则中的报文处理动作对所述待发送报文进行加速处理。硬件需要向主缓存发起缓存申请,申请缓存所述待发送报文,并检测所述申请是否成功;当检测到所述申请已成功时,所述硬件则通过直接存储器访问(DMA,Direct Memory Access)的方式将所述待发送报文以及所述报文特征一起存入至主缓存,并由硬件对所述待发送报文进行缓存。
具体地,所述硬件通过主缓存维护有一套空闲链表和使用内存链表,用于管理对所述待发送报文的缓存申请和缓存释放,当硬件向所述主缓存发起对所述待发送报文的缓存申请成功时,则先通过主缓存从所述空闲链表中得到缓存空间,然后再通过DMA的方式将所述待发送报文存入至所述主缓存,对所述待发送报文进行缓存;而当所述硬件向所述主缓存发起对所述待发送报文的缓存释放成功时,则先通过所述主缓存从所述使用内存链表中释放空间,然后再通过DMA的方式将所述待发送报文从所述主缓存中移出,并对所述待发送报文释放缓存,如此,通过硬件对所述待发送报文进行缓存和释放,能够降低处理器的负担,从而起到报文加速的效果。当确定将所述待发送报文和所述报文特征一起缓存到主缓存后,发送消息告之处理器,由处理器去主缓存中提取所述待发送报文的报文特征,并进一步检测所述报文特征与软件加速规则是否匹配。
这里,检测所述报文特征与软件加速规则中的报文特征是否匹配,与步骤102中检测所述报文特征与硬件加速规则中的报文特征是否匹配的方法大致相同,其相同之处在此不再赘述,其不同之处在于,检测所述报文特征的匹配由所述处理器中的软件功能模块完成,并且加速规则属于软件加速规则。
在本发明实施例中,当所述处理器检测到所述报文特征与所述软件加速规则不匹配时,获取硬件修改指令,根据所述硬件修改指令对所述待发送报文进行报文修改。
这里,所述硬件修改指令包括修改报文指令和删除报文指令,并且,所述硬件修改指令可根据自身需求在接收待发送报文之前自行增、减设置,在此并不限制。例如,所述硬件修改指令为修改报文的MAC地址,则可以在所述待发送报文输出MAC地址的字段期间,不输出原始MAC地址的内容,而是根据获取到的报文修改指令,输出预设好的MAC地址内容,如此,通过硬件来取代现有技术中通过处理器对待发送报文进行报文修改,能够达到报文加速的目的;又如,预设报文指令为删除报文的虚拟局域网(VLAN,Virtual Local AreaNetwork)内容,则硬件可以在所述待发送报文输出VLAN字段期间,不输出VLAN的内容,而是输出VLAN后续的内容,如此,通过硬件取代现有技术中通过处理器对报文进行删除VLAN字段的修改,能够达到报文加速的目的。
当所述处理器检测到所述报文特征与所述软件加速规则中的其中一个报文特征匹配时,则认为所述报文特征与所述软件加速规则已匹配,这时,硬件获取所述软件规则中与所述报文特征相匹配的报文处理动作,并检测所述待发送报文是否能硬件加速。
步骤102,所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。
这里,当处理器检测到所述待发送报文能硬件加速时,则将软件加速规则中与所述报文特征相匹配的报文处理动作,配置到所述硬件加速规则中,并通过DMA的方式将所述待发送报文从所述主缓存中移出,由硬件从所述主缓存中释放所述待发送报文占用的内存,如此,能够在所述硬件再次获取到与所述报文特征相同的待发送报文时,能与所述硬件加速规则相匹配,根据所述硬件加速规则对所述待发送报文进行处理,例如,由硬件对所述待发送报文进行路由或网络地址转换,修改并发送到指定端口。
而当所述处理器检测到所述待发送报文不能硬件加速时,则直接通过DMA的方式将所述待发送报文从主缓存中移出,并由硬件对所述待发送报文进行缓存释放,并发送。
在本发明实施例中,所述方法还包括:所述报文特征与软件加速规则和硬件加速规则均不匹配时,则发送所述待发送报文到相应的软件功能模块,并检测所述待发送报文是否在所述软件功能模块终结;所述待发送报文不在所述软件功能模块终结时,获取所述软件功能模块的报文处理动作,并检测经所述软件模块处理后的所述待发送报文是否能软件加速;所述待发送报文能软件加速时,将所述报文特征以及所述软件功能模块的报文处理动作配置到所述软件加速规则,并由硬件通过DMA的方式将所述待发送报文从所述主缓存中移出,释放缓存并发送所述待发送报文。
这里,所述相应的软件功能模块是指,在所述报文特征中的各层数据中,与当前软件功能模块相比,其下一层软件功能模块,根据所述报文特征将所述待发送报文发送到下一层软件功能模块中进行处理,并检测所述待发送报文是否在所述下一层软件功能模块中终结;当检测到所述待发送报文在所述下一层软件功能模块中终结时,则所述下一层软件功能模块直接对所述待发送报文进行处理;当检测到所述待发送报文不在所述下一层软件功能模块终结时,则检测所述待发送报文是否能软件加速,当检测到所述待发送报文能软件加速时,将所述下一层软件功能模块的报文处理动作和所述报文特征配置到所述软件加速规则中,这样,便于所述处理器再次获取到与所述报文特征相同的待发送报文时,能与所述软件加速规则相匹配,并通过软件对所述待发送报文进行加速处理。
当检测所述待发送报文的所述报文特征与所述软件加速规则已匹配,或检测到所述待发送报文不在所述软件功能模块终结时,并且所述待发送报文需要报文修改,则在所述下一层软件功能模块对所述待发送报文进行处理,获取所述待发送报文的修改编码,将获得的所述修改编码发送到所述硬件,并告诉所述硬件需要所述硬件对所述待发送报文占用的缓存进行释放,硬件接收到所述处理器发送的消息后,根据所述修改编码修改所述待发送报文,并通过DMA的方式将所述待发送报文从所述主缓存中移出,释放所述待发送报文占用在所述主缓存的缓存后,发送所述待发送报文。
图2为本发明实施例一种报文加速装置的组成结构示意图;如图2所示,所述装置包括:检测单元201、处理单元202;其中,
所述检测单元201,用于根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与硬件加速规则不匹配但与软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速;
所述处理单元202,用于所述检测单元201检测到所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。
在实际应用中,所这检测单元201可以根据不同条件或功能的报文,由所述检测单元201中相应的子检测单元完成,并且,每个子检测单元可以检测一项功能或条件的报文。在本发明实施例中,所述报文特征通常集中在待发送报文的报文头中的若干个字节内,所述装置接收到待发送报文时,通过将所述待发送报文的报文头中的若干个字节,对照标准报文格式进行分析,根据分析结果得出所述待发送报文的报文特征。例如,依照以太网的标准协议,对所述待发送报文的报文头中的前六个字节进行分析,即对所述待发送报文的目的MAC地址进行分析,如果分析出所述待发送报文的目的MAC地址为ff:ff:ff:ff:ff:ff,则认为所述待发送报文为广播报文;如果所述待发送报文的目的MAC地址为01:00:5e:xx:xx:xx,则认为所述待发送报文为组播报文。其中,所述ff:ff:ff:ff:ff:ff和01:00:5e:xx:xx:xx就是所述待发送报文的报文特征。通过所述报文特征能够在所述待发送报文需要软件功能模块处理时,对软件功能模块的分析过程起到加速的作用。
在分析出所述报文特征后,检测单元201根据分析出的所述报文特征,通过MAC地址学习和查找的方式检测所述待发送报文是否为本地报文,这里所述的本地报文是指局域网内的报文;当检测单元201检测到所述报文是本发报文时,则通过本地报文交换的方式对所述待发送报文进行加速;当检测单元201检测到所述待发送报文不是本地报文时,则检测所述报文特征与硬件加速规则是否匹配。其中,所述硬件加速规则中包括有至少两个历史报文特征,并且每个报文特征都有与其相匹配的报文处理动作。当检测单元201检测到所述报文特征与所述硬件加速规则中的其中一个报文特征匹配时,则认为所述报文特征与所述硬件加速规则匹配,这时,检测单元201中的硬件功能模块就可以得到所述硬件加速规则中的报文处理动作,并可以通过所述硬件加速规则中的报文处理动作对所述待发送报文进行硬件加速处理;例如:所述报文特征为:ff:ff:ff:ff:ff:ff,则将所述报文特征ff:ff:ff:ff:ff:ff与硬件加速规则中的所有报文特征进行匹配,若匹配到硬件加速规则中也有报文特征ff:ff:ff:ff:ff:ff,则认为当前报文特征ff:ff:ff:ff:ff:ff与硬件加速规则匹配,可以由硬件加速规则中定义的报文处理动作对当前待发送报文进行加速处理;如果检测单元201检测到所述硬件加速规则中没有匹配的报文特征ff:ff:ff:ff:ff:ff时,则认为所述报文特征与所述硬件加速规则不匹配,这时,所述检测单元201中的硬件功能模块无法得知所述待发送报文的报文处理动作,不能通过所述硬件加速规则中的报文处理动作对所述待发送报文进行加速处理,则检测所述报文特征与软件加速规则是否匹配。
在本发明实施例中,所述装置还包括缓存单元203,当所述检测单元201检测到所述报文特征与所述硬件加速规则不匹配时,向主缓存发起缓存申请,申请缓存所述待发送报文,检测所述申请是否成功,并将检测结果发送到缓存单元203;所述缓存单元203在所述检测单元201检测到所述申请已成功时,将所述待发送报文以及所述报文特征一起缓存至主缓存。
具体地,所述缓存单元203通过主缓存维护有一套空闲链表和使用内存链表,用于管理对待发送报文的缓存申请和缓存释放,当所述检测单元201通过所述缓存单元203向所述主缓存发起对所述待发送报文的缓存申请时,检测单元201检测所述缓存申请是否成功,当检测单元201检测到所述申请成功时,将申请结果发送到缓存单元203,由所述缓存单元203从主缓存的空闲链表中得到缓存空间,并通过DMA的方式将所述待发送报文存入所述主缓存,对所述待发送报文进行报文缓存;而当所述检测单元201通过所述缓存单元203向所述主缓存发起对所述待发送报文的缓存释放时,检测单元201检测所述缓存释放是否成功,所述检测单元201检测到所述释放成功时,将缓存释放结果发送到所述缓存单元203,由所述缓存单元203从所述主缓存中对应缓存所述待发送报文的使用内存链表中释放空间,然后再通过DMA的方式将所述待发送报文从所述主缓存在移出,并释放缓存。这里,所述缓存单元203可以为硬件模块,通过所述缓存单元203对所述待发送报文进行报文缓存和缓存释放,能够降低处理器的负担,对待发送报文起到加速的效果。
当所述缓存单元203将所述待发送报文和所述报文特征一起缓存到主缓存后,发送消息告之处理器,由处理器去主缓存中提取所述待发送报文的报文特征,并由所述检测单元201检测所述报文特征与软件加速规则是否匹配。
在本发明实施例中,检测所述报文特征与软件加速规则中的报文特征是否匹配的方法,与检测所述报文特征与硬件加速规则中的报文特征是否匹配的方法大致相同,其相同之处在此不再赘述,其不同之处在于,检测所述报文特征与软件加速规则是否匹配由所述处理器中的软件功能模块完成,并且加速规则属于软件加速规则。
当所述报文特征与所述软件加速规则不匹配时,将检测结果发送给所述处理单元202,由所述处理单元202获取硬件修改指令,根据所述硬件修改指令对所述待发送报文进行报文处理;这里,所述硬件修改指令包括修改报文指令和删除报文指令,并且,所述硬件修改指令可根据自身需求在接收待发送报文之前自行增、减设置,在此并不限制。例如,所述硬件修改指令为修改报文的MAC地址,则可以在所述待发送报文输出MAC地址的字段期间,不输出原始MAC地址的内容,而是根据获取到的报文修改指令,输出预设好的MAC地址内容,这时,所述处理单元202可以是硬件功能模块,通过所述处理单元202取代现有技术中使用所述处理器对待发送报文进行报文修改,能够达到报文加速的目的;又如,预设报文指令为删除报文的VLAN内容,则硬件可以在所述待发送报文输出VLAN字段期间,不输出VLAN的内容,而是输出VLAN后续的内容,如此,通过处理单元202取代现有技术中通过处理器对报文进行删除VLAN字段的修改,能够达到报文加速的目的。
当所述报文特征与所述软件加速规则中的其中一个报文特征匹配时,则认为所述报文特征与所述软件加速规则已匹配,这时获取所述软件规则中与所述报文特征相匹配的报文处理动作,并检测所述待发送报文是否能硬件加速。
当检测单元201检测到所述待发送报文能硬件加速时,则将所述检测结果发送给所述处理单元202,由所述处理单元202将所述软件加速规则中与所述报文特征相匹配的报文处理动作,配置到所述硬件加速规则中,并由所述缓存单元203通过DMA的方式将所述待发送报文从所述主缓存中移出,并释放所述待发送报文占用的内存,如此,能够在所述装置再次获取到与所述报文特征相同的待发送报文时,能与所述硬件加速规则相匹配,并根据所述硬件加速规则对所述待发送报文进行处理,例如,在所述硬件加速规则中,所述检测单元201和所述处理单元202为硬件功能模块,便由所述检测单元201检测所述待发送报文是否需要修改路由连接或网络地址转换连接,当所述检测单元201检测到所述待发送报文需要修改路由连接或网络地址转换连接时,将检测结果发送到所述处理单元202,由处理单元202对所述待发送报文进行路由连接或网络地址转换连接的修改。
而当所述检测单元201检测到所述待发送报文不能硬件加速时,则将检测结果发送到所述处理单元202,由所述处理单元202告之所述缓存单元203,由缓存单元203直接通过DMA的方式将所述待发送报文从主缓存中移出,并对所述待发送报文进行缓存释放。
在本发明实施例中,所述检测单元201还用于所述报文特征与软件加速规则均不匹配时,发送所述待发送报文到相应的软件功能模块,并检测所述待发送报文是否在所述软件功能模块终结;所述待发送报文不在所述软件功能模块终结时,获取所述软件功能模块的报文处理动作,并检测经所述软件模块处理后的所述待发送报文是否能软件加速,并将检测结果发送到所述处理单元202;所述处理单元202在所述检测单元201检测到所述待发送报文能软件加速时,将所述报文特征以及所述软件功能模块的报文处理动作配置到所述软件加速规则,根据所述软件加速规则对所述待发送报文进行处理。
这里,所述相应的软件功能模块是指,所述报文特征中的各层数据中,相比当前软件功能模块的下一层软件功能模块,由所述检测单元201根据所述报文特征,将所述待发送报文发送到下一层软件功能模块中进行处理,并检测所述待发送报文是否在所述下一层软件功能模块中终结;当所述检测单元201检测到所述待发送报文在所述下一层软件功能模块中终结时,则由所述处理单元202在所述下一层软件功能模块直接对所述待发送报文进行处理;当所述检测单元201检测到所述待发送报文不在所述下一层软件功能模块终结时,检测所述待发送报文是否能软件加速,所述待发送报文能软件加速时,则将检测结果发送给所述处理单元202,由所述处理单元202将所述下一层软件功能模块的报文处理动作和所述报文特征配置到所述软件加速规则中,这样,便于所述处理器再次获取到与所述报文特征相同的待发送报文时,能与所述软件加速规则相匹配,并通过所述处理器中的软件功能模块对所述待发送报文进行加速处理。
在本发明实施例中,当所述待发送报文的所述报文特征与所述软件加速规则已匹配,或所述待发送报文不在所述软件功能模块终结时,并且所述待发送报文需要报文修改,则由所述检测单元201对所述待发送报文进行处理后,获取所述待发送报文的修改编码,将获得的所述修改编码发送到所述处理单元202,并告诉所述处理单元202需要所述缓存单元203对所述待发送报文占用的缓存进行释放,所述处理单元202接收到所述检测单元201发送的消息后,根据所述修改编码修改所述待发送报文,并由缓存单元203通过DMA的方式将所述待发送报文从所述主缓存中移出,释放所述待发送报文占用在所述主缓存的缓存后,发送所述待发送报文。
在实际应用中,所述检测单元201、处理单元202和缓存单元203均可由位于所述报文加速装置的中央理器(CPU)、微处理器(MPU)、数字信号处理器(DSP)、或现场可编程门阵列(FPGA)等实现。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用硬件实施例、软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器和光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
以上所述,仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。
Claims (12)
1.一种报文加速方法,其特征在于,所述方法包括:
根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与硬件加速规则不匹配但与软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速;
所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。
2.根据权利要求1所述的方法,其特征在于,所述报文特征与所述软件加速规则不匹配时,所述方法还包括:
发送所述待发送报文到相应的软件功能模块,并检测所述待发送报文是否在所述软件功能模块终结;
所述待发送报文不在所述软件功能模块终结时,获取所述软件功能模块的报文处理动作,并检测经所述软件功能模块处理后的所述待发送报文是否能软件加速;
所述待发送报文能软件加速时,将所述报文特征以及所述软件功能模块的报文处理动作配置到所述软件加速规则,根据所述软件加速规则对所述待发送报文进行处理。
3.根据权利要求2所述的方法,其特征在于,所述待发送报文与所述软件加速规则匹配或所述待发送报文不在所述软件功能模块终结时,所述方法还包括:
获取所述待发送报文的修改编码,根据获取到的所述修改编码对所述待发送报文进行处理。
4.根据权利要求1所述的方法,其特征在于,所述报文特征与所述软件加速规则不匹配时,所述方法还包括:
获取硬件修改指令;
根据获取到的硬件修改指令对所述待发送报文进行处理。
5.根据权利要求1所述的方法,其特征在于,所述待发送报文与所述硬件加速规则不匹配时,所述方法还包括:
申请缓存所述待发送报文,并检测所述申请是否成功;
所述申请已成功时,通过直接存储器访问DMA的方式将所述待发送报文存入主缓存,并对所述待发送报文进行缓存。
6.根据权利要求5所述的方法,其特征在于,所述待发送报文不能硬件加速或不能软件加速时,所述方法还包括:
通过DMA的方式将所述待发送报文从所述主缓存移出,并释放缓存。
7.一种报文加速装置,其特征在于,所述装置包括:检测单元和处理单元;其中,
所述检测单元,用于根据待发送报文的报文特征检测到所述待发送报文不是本地报文、且所述报文特征与硬件加速规则不匹配但与软件加速规则匹配时,获取所述软件加速规则中的报文处理动作,并检测经所述软件加速规则处理后的所述待发送报文是否能硬件加速;
所述处理单元,用于所述检测单元检测到所述待发送报文能硬件加速时,将所述报文特征和所述软件加速规则中的报文处理动作配置到所述硬件加速规则中,根据所述硬件加速规则对所述待发送报文进行处理。
8.根据权利要求7所述的装置,其特征在于,所述检测单元,还用于所述报文特征与所述软件加速规则不匹配时,发送所述待发送报文到相应的软件功能模块,并检测所述待发送报文是否在所述软件功能模块终结;所述待发送报文不在所述软件功能模块终结时,获取所述软件功能模块的报文处理动作,并检测经所述软件功能模块处理后的所述待发送报文是否能软件加速;
所述处理单元,还用于所述检测单元检测到所述待发送报文能软件加速时,将所述报文特征以及所述软件功能模块的报文处理动作配置到所述软件加速规则,并根据所述软件加速规则对所述待发送报文进行处理。
9.根据权利要求8所述的装置,其特征在于,所述处理单元,还用于所述检测单元检测到所述报文特征与所述软件加速规则匹配,或检测到所述待发送报文不在所述软件功能模块终结时,获取所述待发送报文的修改编码,根据获取到的所述修改编码对所述待发送报文进行处理。
10.根据权利要求7所述的装置,其特征在于,所述处理单元,还用于所述检测单元检测到所述报文特征与所述软件加速规则不匹配时,获取硬件修改指令,根据获取到的所述硬件修改指令对所述待发送报文进行处理。
11.根据权利要求7所述的装置,其特征在于,所述装置还包括:缓存单元;
所述检测单元,还用于检测到所述报文特征与所述硬件加速规则不匹配时,申请缓存所述待发送报文,并检测所述申请是否成功;
所述缓存单元,用于所述检测单元检测到所述申请已成功时,通过DMA的方式将所述待发送报文存入主缓存,并对所述待发送报文进行缓存。
12.根据权利要求11所述的装置,其特征在于,所述缓存单元,还用于所述检测单元检测到所述待发送报文不能硬件加速或不能软件加速时,通过DMA的方式将所述待发送报文从所述主缓存移出,并释放缓存。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610530583.8A CN107592287A (zh) | 2016-07-07 | 2016-07-07 | 一种报文加速方法及装置 |
PCT/CN2017/085912 WO2018006663A1 (zh) | 2016-07-07 | 2017-05-25 | 一种报文加速方法、装置及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610530583.8A CN107592287A (zh) | 2016-07-07 | 2016-07-07 | 一种报文加速方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN107592287A true CN107592287A (zh) | 2018-01-16 |
Family
ID=60901387
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610530583.8A Pending CN107592287A (zh) | 2016-07-07 | 2016-07-07 | 一种报文加速方法及装置 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN107592287A (zh) |
WO (1) | WO2018006663A1 (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111371693A (zh) * | 2018-12-25 | 2020-07-03 | 深圳市中兴微电子技术有限公司 | 一种通过硬件、软件快速报文转发的方法和系统 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120159132A1 (en) * | 2010-12-16 | 2012-06-21 | International Business Machines Corporation | Accelerating Data Packet Parsing |
CN103164215A (zh) * | 2011-08-30 | 2013-06-19 | 三星电子株式会社 | 数据处理系统和用于在异类加速器之间进行切换的方法 |
CN105099918A (zh) * | 2014-05-13 | 2015-11-25 | 华为技术有限公司 | 一种数据查找匹配的方法和装置 |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102769574B (zh) * | 2012-08-06 | 2015-04-08 | 华为技术有限公司 | 一种能够进行业务硬件加速的装置及其方法 |
WO2014160652A1 (en) * | 2013-03-25 | 2014-10-02 | Marvell Word Trade Ltd. | Hardware acceleration for routing programs |
-
2016
- 2016-07-07 CN CN201610530583.8A patent/CN107592287A/zh active Pending
-
2017
- 2017-05-25 WO PCT/CN2017/085912 patent/WO2018006663A1/zh active Application Filing
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120159132A1 (en) * | 2010-12-16 | 2012-06-21 | International Business Machines Corporation | Accelerating Data Packet Parsing |
CN103164215A (zh) * | 2011-08-30 | 2013-06-19 | 三星电子株式会社 | 数据处理系统和用于在异类加速器之间进行切换的方法 |
CN105099918A (zh) * | 2014-05-13 | 2015-11-25 | 华为技术有限公司 | 一种数据查找匹配的方法和装置 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111371693A (zh) * | 2018-12-25 | 2020-07-03 | 深圳市中兴微电子技术有限公司 | 一种通过硬件、软件快速报文转发的方法和系统 |
CN111371693B (zh) * | 2018-12-25 | 2023-01-10 | 深圳市中兴微电子技术有限公司 | 一种通过硬件、软件快速报文转发的方法和系统 |
Also Published As
Publication number | Publication date |
---|---|
WO2018006663A1 (zh) | 2018-01-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110022264B (zh) | 控制网络拥塞的方法、接入设备和计算机可读存储介质 | |
US10218603B2 (en) | Multicast message translation in a network device | |
CN103281257B (zh) | 一种协议报文处理方法和设备 | |
CN106411778B (zh) | 数据转发的方法及装置 | |
CN113285931A (zh) | 流媒体的传输方法、流媒体服务器及流媒体系统 | |
US9130957B2 (en) | Data communication apparatus and method | |
CN102629944B (zh) | 网络加速方法、装置及系统 | |
CN115225734A (zh) | 一种报文处理方法和网络设备 | |
CN106716974B (zh) | 访问分发方法、装置及系统 | |
CN107592287A (zh) | 一种报文加速方法及装置 | |
US9985926B2 (en) | Address acquiring method and network virtualization edge device | |
CN115296956B (zh) | 一种内核的隧道转发方法、装置、电子设备及存储介质 | |
CN106656804A (zh) | 低延时的报文转发方法、装置及交换机 | |
CN115314643B (zh) | 一种实现净切换的方法、系统、设备及存储介质 | |
CN107231567A (zh) | 一种报文传输方法、装置及系统 | |
CN107683594B (zh) | 通信控制设备、通信控制方法、网络交换机、路由控制方法以及通信系统 | |
CN102801603B (zh) | 一种网络地址翻译加速的分流控制方法及装置 | |
WO2021103822A1 (zh) | 用于获取共用最大分段大小mss的方法及装置 | |
US10320661B2 (en) | Communication device and communication method | |
CN110650169A (zh) | 一种终端设备升级方法和装置 | |
US9485107B2 (en) | System and method for distributed internet group management protocol processing | |
CN109660495B (zh) | 一种文件传输方法和装置 | |
CN113660530B (zh) | 节目流数据抓取方法、装置、计算机设备及可读存储介质 | |
CN109495570B (zh) | 采样报文的转发方法、装置及数据中心 | |
CN103581344B (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 | ||
WD01 | Invention patent application deemed withdrawn after publication |
Application publication date: 20180116 |
|
WD01 | Invention patent application deemed withdrawn after publication |