CN111010346B - 基于动态路由的报文处理方法、设备、存储介质及装置 - Google Patents

基于动态路由的报文处理方法、设备、存储介质及装置 Download PDF

Info

Publication number
CN111010346B
CN111010346B CN201911341649.9A CN201911341649A CN111010346B CN 111010346 B CN111010346 B CN 111010346B CN 201911341649 A CN201911341649 A CN 201911341649A CN 111010346 B CN111010346 B CN 111010346B
Authority
CN
China
Prior art keywords
target
message processing
function
dynamic
library
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
Application number
CN201911341649.9A
Other languages
English (en)
Other versions
CN111010346A (zh
Inventor
王浩
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sangfor Technologies Co Ltd
Original Assignee
Sangfor Technologies Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Sangfor Technologies Co Ltd filed Critical Sangfor Technologies Co Ltd
Priority to CN201911341649.9A priority Critical patent/CN111010346B/zh
Publication of CN111010346A publication Critical patent/CN111010346A/zh
Application granted granted Critical
Publication of CN111010346B publication Critical patent/CN111010346B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/02Topology update or discovery
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44521Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本发明涉及动态路由技术领域,公开了一种基于动态路由的报文处理方法、设备、存储介质及装置。本发明通过若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;在所述目标函数集合中查找与所述目标指令类型对应的目标函数;通过所述目标函数对所述报文处理指令进行处理,从而通过预设动态函数库即可实现进程的处理,而无需通过负责各个协议的进程进行单独处理,达到减少通信损耗的目的。

Description

基于动态路由的报文处理方法、设备、存储介质及装置
技术领域
本发明涉及动态路由技术领域,尤其涉及基于动态路由的报文处理方法、设备、存储介质及装置。
背景技术
动态路由Quagga是一个开源的动态路由软件,它提供的命令行,可以使用quagga将Linux机器打造成一台功能完备的路由器。Quagga运行时要运行多个守护进程,包括路由信息协议进程ripd、开放式最短路径优先协议进程ospfd、边界网关协议进程bgpd和斑马zebra等多个动态路由协议进程,其中,zebra守护进程用来更新内核的路由表,而其他的守护进程负责进行相应路由选择协议的路由更新。
目前动态路由Quagga运行时要运行多个守护进程,这些进程都需要单独进行管理,并且在数据交互时都需要各自进行通讯处理,从而大大增大了通信的性能损耗。
发明内容
本发明的主要目的在于提供基于动态路由的报文处理方法、设备、存储介质及装置,旨在解决如何降低数据报文交互功耗的技术问题。
为实现上述目的,本发明提供一种基于动态路由的报文处理方法,所述基于动态路由的报文处理方法包括以下步骤:
若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;
根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;
在所述目标函数集合中查找与所述目标指令类型对应的目标函数;
通过所述目标函数对所述报文处理指令进行处理。
优选地,所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合之前,所述方法还包括:
获取动态路由中的协议报文处理逻辑;
分别对所述协议报文处理逻辑进行编译,生成预设动态函数库。
优选地,所述分别对所述协议报文处理逻辑进行编译,生成预设动态函数库,包括:
分别对所述协议报文处理逻辑加入第一编译动态库参数;
通过所述第一编译动态库参数对所述协议报文处理逻辑进行编译,得到函数集合;
将所述函数集合进行组装生成预设动态函数库。
优选地,所述预设动态函数库包括路由信息协议函数库、开放式最短路径优先协议函数库和边界网关协议函数库;
所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合,包括:
根据所述目标进程信息的协议类型从所述路由信息协议函数库、开放式最短路径优先协议函数库和边界网关协议函数库中查找与所述目标进程信息对应的目标函数集合。
优选地,所述目标指令类型为发送指令,包括:
在所述目标函数集合中查找与所述发送指令对应的发送函数;
所述通过所述目标函数对所述报文处理指令进行处理,包括:
提取所述报文处理指令中的待发送报文;
通过所述发送函数对所述待发送报文进行发送处理。
优选地,所述目标指令类型为接收指令;
在所述目标函数集合中查找与所述接收指令对应的接收函数;
所述通过所述目标函数对所述报文处理指令进行处理,包括:
提取所述报文处理指令中的待接收报文;
通过所述接收函数对所述待接收报文进行接收处理。
优选地,所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合之前,所述方法还包括:
获取所述动态路由中的公共代码逻辑,将所述公共代码逻辑加入第二编译动态库参数;
通过所述第二编译动态库参数对所述公共代码逻辑进行编译,得到配置函数库;
通过所述配置函数库对所述预设动态函数库进行更新,得到目标函数库;
所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合,包括:
根据所述目标进程信息从目标函数库中查找与所述目标进程信息对应的目标函数集合。
此外,为实现上述目的,本发明还提出一种基于动态路由的报文处理设备,所述基于动态路由的报文处理设备包括:存储器、处理器及存储在所述存储器上并在所述处理器上运行基于动态路由的报文处理程序,所述基于动态路由的报文处理程序被所述处理器执行时实现如上文所述的基于动态路由的报文处理方法的步骤。
此外,为实现上述目的,本发明还提出一种存储介质,所述存储介质上存储有基于动态路由的报文处理程序,所述基于动态路由的报文处理程序被处理器执行时实现如上文所述的基于动态路由的报文处理方法的步骤。
此外,为实现上述目的,本发明还提出一种基于动态路由的报文处理装置,所述基于动态路由的报文处理装置包括:
获取模块,用于若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;
查找模块,用于根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;
所述查找模块,还用于在所述目标函数集合中查找与所述目标指令类型对应的目标函数;
处理模块,用于通过所述目标函数对所述报文处理指令进行处理。
本发明提供的技术方案,通过若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;在所述目标函数集合中查找与所述目标指令类型对应的目标函数;通过所述目标函数对所述报文处理指令进行处理,从而通过预设动态函数库即可实现进程的处理,而无需通过负责各个协议的进程进行单独处理,达到减少通信损耗的目的。
附图说明
图1是本发明实施例方案涉及的硬件运行环境的基于动态路由的报文处理设备结构示意图;
图2为本发明基于动态路由的报文处理方法一实施例的流程示意图;
图3为本发明示例的动态路由进行进程处理的结构示意图;
图4为本发明基于动态路由的报文处理方法一实施例的进程处理结构示意图;
图5为本发明基于动态路由的报文处理方法另一实施例的流程示意图;
图6为本发明基于动态路由的报文处理方法再一实施例的流程示意图;
图7为本发明基于动态路由的报文处理装置一实施例的结构框图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
参照图1,图1为本发明实施例方案涉及的硬件运行环境的基于动态路由的报文处理设备结构示意图。
如图1所示,该基于动态路由的报文处理设备可以包括:处理器1001,例如中央处理器(Central Processing Unit,CPU),通信总线1002、用户接口1003,网络接口1004,存储器1005。其中,通信总线1002用于实现这些组件之间的连接通信。用户接口1003可以包括显示屏(Display),可选用户接口1003还可以包括标准的有线接口以及无线接口,而用户接口1003的有线接口在本发明中可为通用串行总线(Universal Serial Bus,USB)接口。网络接口1004可选的可以包括标准的有线接口以及无线接口(如WI-FI接口)。存储器1005可以是高速随机存取存储器(Random Access Memory,RAM);也可以是稳定的存储器,比如,非易失存储器(Non-volatile Memory),具体可为,磁盘存储器。存储器1005可选的还可以是独立于前述处理器1001的存储装置。
本领域技术人员可以理解,图1中示出的结构并不构成对基于动态路由的报文处理设备的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
如图1所示,作为一种计算机存储介质的存储器1005中可以包括操作系统、网络通信模块、用户接口模块以及基于动态路由的报文处理程序。
在图1所示的基于动态路由的报文处理设备中,网络接口1004主要用于连接后台服务器,与所述后台服务器进行数据通信;用户接口1003主要用于连接外设;所述基于动态路由的报文处理设备通过处理器1001调用存储器1005中存储的基于动态路由的报文处理程序,并执行本发明实施例提供的基于动态路由的报文处理方法。
基于上述硬件结构,提出本发明基于动态路由的报文处理方法的实施例。
参照图2,图2为本发明基于动态路由的报文处理方法一实施例的流程示意图。
在图2实施例中,所述基于动态路由的报文处理方法包括以下步骤:
步骤S10:若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息。
需要说明的是,本实施例的执行主体为基于动态路由的报文处理设备,还可为其他可实现相同或相似功能的设备,本实施例对此不作限制,在本实施例中,以基于动态路由的报文处理设备为例进行说明。
在本实施例中,所述动态路由以Quagga路由为例进行说明,由于Quagga运行时要运行多个守护进程,包括路由信息协议进程ripd、开放式最短路径优先协议进程ospfd、边界网关协议进程bgpd和斑马zebra等多个动态路由协议进程,图3所示的示例的动态路由进行进程处理的结构示意图,包括路由信息协议(Routing Information Protocol,RIP)进程、开放式最短路径优先(Open Shortest Path First,OSPF)进程以及边界网关协议(Border Gateway Protocol,BGP)进程,各个分别独立进行通信,然后通过zebra进程实现与数据转发层即系统内核之间的配置下发以及数据报文交互,但是这种静态结构容易造成通信损耗。
可以理解的是,所述报文处理指令包括数据的发送或接收以及数据的配置信息等,还可包括其他报文处理信息,本实施例对此不作限制。
步骤S20:根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合。
在本实施例中,所述预设动态函数库包括目标函数集合,即路由信息协议函数库、开放式最短路径优先协议函数库以及边界网关协议函数库等,从而将协议处理逻辑封装成函数库的形式,实现数据的动态处理。
进一步地,所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合,包括:
根据所述目标进程信息的协议类型从所述路由信息协议函数库、开放式最短路径优先协议函数库和边界网关协议函数库中查找与所述目标进程信息对应的目标函数集合。
由于函数库为一个文件包含了一些编译好的代码和数据,这些编译好的代码和数据可以在事后供其他的程序使用。程序函数库可以使整个程序更加模块化,更容易重新编译,而且更方便升级,从而通过函数库直接对进程进行处理,减少各自单独进行通信的次数,如图4所示的进程处理结构示意图,将动态路由需要使用的协议进程封装为函数库,通过Quagga函数库进行管理,其中,包括信息协议函数库、开放式最短路径优先协议函数库以及边界网关协议函数库等,在理由管理进程中,还包括其他功能的函数库,例如实现配置进程的函数库,通过封装的函数库直接实现与数据转发层之间的配置下发以及数据报文的交互,从而大大减少了进程之间的数据通信,降低了通信损耗。
步骤S30:在所述目标函数集合中查找与所述目标指令类型对应的目标函数。
需要说明的是,由于不同协议的报文需要不同的协议进程进行处理,即通过不同的函数库进行处理,从而可根据报文的类型确定当前报文所使用的协议信息,即通过报文的包头进行识别可得到当前报文所使用的的协议。
可以理解的是,RIP协议是内部网关协议(Interior Gateway Protocol,IGP)中最先得到广泛使用的协议,RIP是一种分布式的基于距离向量的路由选择协议,是因特网的标准协议,其最大优点就是实现简单,开销较小,OSPF协议是一个内部网关协议,用于在单一自治系统(autonomous system,AS)内决策路由,BGP协议,是运行于传输控制协议(Transmission Control Protocol,TCP)上的一种自治系统的路由协议,BGP是唯一一个用来处理像因特网大小的网络的协议,也是唯一能够妥善处理好不相关路由域间的多路连接的协议,从而可根据协议类型选择对应的目标函数进行处理,例如属于RIP协议进程的报文在Quagga函数库中则调用信息协议函数库进行报文的处理。
步骤S40:通过所述目标函数对所述报文处理指令进行处理。
继续如图4所示,在选择的目标函数集合为信息协议函数库时,则直接通过调用信息协议函数库中报文处理函数与数据转发层进行数据报文交互,实现数据报文的处理。
本实施例通过上述方案,通过若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;在所述目标函数集合中查找与所述目标指令类型对应的目标函数;通过所述目标函数对所述报文处理指令进行处理,从而通过预设动态函数库即可实现进程的处理,而无需通过负责各个协议的进程进行单独处理,达到减少通信损耗的目的。
参照图5,图5为本发明基于动态路由的报文处理方法另一实施例的流程示意图,基于上述图2所示的一实施例,提出本发明基于动态路由的报文处理方法的另一实施例,所述步骤S20之前,所述方法还包括:
步骤S201,获取动态路由中的协议报文处理逻辑。
在本实施例中,主要为对动态路由中的动态路由进程进行封装,生成独立的函数库,在需要使用时,直接进行调用即可。
步骤S202,分别对所述协议报文处理逻辑进行编译,生成预设动态函数库。
进一步地,所述步骤S202,包括:
分别对所述协议报文处理逻辑加入第一编译动态库参数;通过所述第一编译动态库参数对所述协议报文处理逻辑进行编译,得到函数集合;将所述函数集合进行组装生成预设动态函数库。
在具体实现中,所述第一编译动态库参数为“-fpic”,在进行编译时,加入参数选项“-fpic”,生成独立的函数库,即生成对应的预设动态函数库,即包括路由信息协议函数库、开放式最短路径优先协议函数库以及边界网关协议函数库,都是通过加入参数选项的方式实现进程逻辑的封装。
本实施例提供的方案,通过分别对所述协议报文处理逻辑加入第一编译动态库参数;通过所述第一编译动态库参数对所述协议报文处理逻辑进行编译,得到函数集合;将所述函数集合进行组装生成预设动态函数库,从而实现对动态路由中的动态路由进程的封装,实现进程的模块化。
参照图6,图6为本发明基于动态路由的报文处理方法再一实施例的流程示意图,基于上述图2所示的一实施例,提出本发明基于动态路由的报文处理方法的再一实施例,所述目标指令类型为发送指令,所述步骤S30,包括:
步骤S301,在所述目标函数集合中查找与所述发送指令对应的发送函数。
需要说明的是,所述报文处理类型为发送处理或者接收处理,还可包括其他处理方式,本实施例对此不作限制,在本实施例中,以发送处理或者接收处理为例进行说明。
进一步地,所述步骤S40,包括:
步骤S401,提取所述报文处理指令中的待发送报文;通过所述发送函数对所述待发送报文进行发送处理。
进一步地,所述目标指令类型为接收指令,所述步骤S30,包括:
步骤S301,在所述目标函数集合中查找与所述发送指令对应的发送函数。
在所述目标函数集合中查找与所述接收指令对应的接收函数;
进一步地,所述步骤S40,包括:
提取所述报文处理指令中的待接收报文;通过所述接收函数对所述待接收报文进行接收处理。
在具体实现中,进程中消息接收的处理逻辑,改为原来的消息发送者,直接调用处理逻辑,比如,RIP函数库中,直接有封装好的rip_recv函数,程序中可以直接调用,完成发送的逻辑,进程中消息发送的处理逻辑,改为调用原来的消息接收者,处理逻辑,比如RIP函数库中,直接有封装好的rip_send函数,程序中可以直接调用,完成接收逻辑。
在本实施例中,路由管理进程加载相应的函数库,根据数据报文区分不同的协议报文,然后调用对应协议的函数库进行处理,比如,收到了RIP协议报文,可以直接调用rip_recv函数进行rip协议报文的处理,对应,如果有需要发送RIP协议报文,直接调用rip_send函数完成。
进一步地,所述步骤S20之前,所述方法还包括:
获取所述动态路由中的公共代码逻辑,将所述公共代码逻辑加入第二编译动态库参数;通过所述第二编译动态库参数对所述公共代码逻辑进行编译,得到配置函数库;通过所述配置函数库对所述预设动态函数库进行更新,得到目标函数库。
需要说明的是,所述第二预设参数选项为“-fpic”,在进行编译时,加入参数选项“-fpic”,生成配置函数库,从而也实现了对公共代码逻辑的封装,即将quagga源码公共代码逻辑,在进行编译时,加入参数选项“-fpic”,生成独立的配置函数库,从而也大大降低了配置信息处理的通讯次数。
相应的,所述步骤S20,包括:
根据所述目标进程信息从目标函数库中查找与所述目标进程信息对应的目标函数集合。
本实施例提供的方案,根据所述报文处理类型调用所述目标函数库中的发送函数或接收函数;通过所述发送函数或接收函数对所述待转发报文进行数据交互,从而通过发送函数或接收函数直接进行数据的交互,而无需再通过zebra进程进行与数据转发层之间的通信,降低了报文处理的通信功耗。
此外,本发明实施例还提出一种存储介质,所述存储介质上存储有基于动态路由的报文处理程序,所述基于动态路由的报文处理程序被处理器执行时实现如上文所述的基于动态路由的报文处理方法的步骤。
由于本存储介质采用了上述所有实施例的全部技术方案,因此至少具有上述实施例的技术方案所带来的所有有益效果,在此不再一一赘述。
此外,参照图7,本发明实施例还提出一种基于动态路由的报文处理装置,所述基于动态路由的报文处理装置包括:
获取模块10,用于若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息。
需要说明的是,本实施例的执行主体为基于动态路由的报文处理设备,还可为其他可实现相同或相似功能的设备,本实施例对此不作限制,在本实施例中,以基于动态路由的报文处理设备为例进行说明。
在本实施例中,所述动态路由以Quagga路由为例进行说明,由于Quagga运行时要运行多个守护进程,包括路由信息协议进程ripd、开放式最短路径优先协议进程ospfd、边界网关协议进程bgpd和斑马zebra等多个动态路由协议进程,图3所示的示例的动态路由进行进程处理的结构示意图,包括路由信息协议(Routing Information Protocol,RIP)进程、开放式最短路径优先(Open Shortest Path First,OSPF)进程以及边界网关协议(Border Gateway Protocol,BGP)进程,各个分别独立进行通信,然后通过zebra进程实现与数据转发层即系统内核之间的配置下发以及数据报文交互,但是这种静态结构容易造成通信损耗。
可以理解的是,所述报文处理指令包括数据的发送或接收以及数据的配置信息等,还可包括其他报文处理信息,本实施例对此不作限制。
查找模块20,用于根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合。
在本实施例中,所述预设动态函数库包括目标函数集合,即路由信息协议函数库、开放式最短路径优先协议函数库以及边界网关协议函数库等,从而将协议处理逻辑封装成函数库的形式,实现数据的动态处理。由于函数库为一个文件包含了一些编译好的代码和数据,这些编译好的代码和数据可以在事后供其他的程序使用。程序函数库可以使整个程序更加模块化,更容易重新编译,而且更方便升级,从而通过函数库直接对进程进行处理,减少各自单独进行通信的次数,如图4所示的进程处理结构示意图,将动态路由需要使用的协议进程封装为函数库,通过Quagga函数库进行管理,其中,包括信息协议函数库、开放式最短路径优先协议函数库以及边界网关协议函数库等,在理由管理进程中,还包括其他功能的函数库,例如实现配置进程的函数库,通过封装的函数库直接实现与数据转发层之间的配置下发以及数据报文的交互,从而大大减少了进程之间的数据通信,降低了通信损耗。
所述查找模块20,还用于在所述目标函数集合中查找与所述目标指令类型对应的目标函数。
需要说明的是,由于不同协议的报文需要不同的协议进程进行处理,即通过不同的函数库进行处理,从而可根据报文的类型确定当前报文所使用的协议信息,即通过报文的包头进行识别可得到当前报文所使用的的协议。
可以理解的是,RIP协议是内部网关协议(Interior Gateway Protocol,IGP)中最先得到广泛使用的协议,RIP是一种分布式的基于距离向量的路由选择协议,是因特网的标准协议,其最大优点就是实现简单,开销较小,OSPF协议是一个内部网关协议,用于在单一自治系统(autonomous system,AS)内决策路由,BGP协议,是运行于传输控制协议(Transmission Control Protocol,TCP)上的一种自治系统的路由协议,BGP是唯一一个用来处理像因特网大小的网络的协议,也是唯一能够妥善处理好不相关路由域间的多路连接的协议,从而可根据协议类型选择对应的目标函数进行处理,例如属于RIP协议进程的报文在Quagga函数库中则调用信息协议函数库进行报文的处理。
处理模块30,用于通过所述目标函数对所述报文处理指令进行处理。
继续如图4所示,在选择的目标函数集合为信息协议函数库时,则直接通过调用信息协议函数库中报文处理函数与数据转发层进行数据报文交互,实现数据报文的处理。
本实施例通过上述方案,通过若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;在所述目标函数集合中查找与所述目标指令类型对应的目标函数;通过所述目标函数对所述报文处理指令进行处理,从而通过预设动态函数库即可实现进程的处理,而无需通过负责各个协议的进程进行单独处理,达到减少通信损耗的目的。
本发明所述基于动态路由的报文处理装置采用了上述所有实施例的全部技术方案,因此至少具有上述实施例的技术方案所带来的所有有益效果,在此不再一一赘述。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者系统不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者系统所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者系统中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。词语第一、第二、以及第三等的使用不表示任何顺序,可将这些词语解释为名称。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如只读存储器、RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。

Claims (9)

1.一种基于动态路由的报文处理方法,其特征在于,所述基于动态路由的报文处理方法包括以下步骤:
若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;
根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;
在所述目标函数集合中查找与所述目标指令类型对应的目标函数;
通过所述目标函数对所述报文处理指令进行处理;
所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合之前,所述方法还包括:
获取所述动态路由中的公共代码逻辑,将所述公共代码逻辑加入第二编译动态库参数;
通过所述第二编译动态库参数对所述公共代码逻辑进行编译,得到配置函数库;
通过所述配置函数库对所述预设动态函数库进行更新,得到目标函数库;
所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合,包括:
根据所述目标进程信息从目标函数库中查找与所述目标进程信息对应的目标函数集合。
2.如权利要求1所述的基于动态路由的报文处理方法,其特征在于,所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合之前,所述方法还包括:
获取动态路由中的协议报文处理逻辑;
分别对所述协议报文处理逻辑进行编译,生成预设动态函数库。
3.如权利要求2所述的基于动态路由的报文处理方法,其特征在于,所述分别对所述协议报文处理逻辑进行编译,生成预设动态函数库,包括:
分别对所述协议报文处理逻辑加入第一编译动态库参数;
通过所述第一编译动态库参数对所述协议报文处理逻辑进行编译,得到函数集合;
将所述函数集合进行组装生成预设动态函数库。
4.如权利要求1至3中任一项所述的基于动态路由的报文处理方法,其特征在于,所述预设动态函数库包括路由信息协议函数库、开放式最短路径优先协议函数库和边界网关协议函数库;
所述根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合,包括:
根据所述目标进程信息的协议类型从所述路由信息协议函数库、开放式最短路径优先协议函数库和边界网关协议函数库中查找与所述目标进程信息对应的目标函数集合。
5.如权利要求1至3中任一项所述的基于动态路由的报文处理方法,其特征在于,所述目标指令类型为发送指令,包括:
在所述目标函数集合中查找与所述发送指令对应的发送函数;
所述通过所述目标函数对所述报文处理指令进行处理,包括:
提取所述报文处理指令中的待发送报文;
通过所述发送函数对所述待发送报文进行发送处理。
6.如权利要求1至3中任一项所述的基于动态路由的报文处理方法,其特征在于,所述目标指令类型为接收指令;
在所述目标函数集合中查找与所述接收指令对应的接收函数;
所述通过所述目标函数对所述报文处理指令进行处理,包括:
提取所述报文处理指令中的待接收报文;
通过所述接收函数对所述待接收报文进行接收处理。
7.一种基于动态路由的报文处理设备,其特征在于,所述基于动态路由的报文处理设备包括:存储器、处理器及存储在所述存储器上并在所述处理器上运行基于动态路由的报文处理程序,所述基于动态路由的报文处理程序被所述处理器执行时实现如权利要求1至6中任一项所述的基于动态路由的报文处理方法的步骤。
8.一种存储介质,其特征在于,所述存储介质上存储有基于动态路由的报文处理程序,所述基于动态路由的报文处理程序被处理器执行时实现如权利要求1至6中任一项所述的基于动态路由的报文处理方法的步骤。
9.一种基于动态路由的报文处理装置,其特征在于,所述基于动态路由的报文处理装置包括:
获取模块,用于若通过动态路由接收到报文处理指令,则获取所述报文处理指令对应的目标指令类型和目标进程信息;
查找模块,用于根据所述目标进程信息从预设动态函数库中查找与所述目标进程信息对应的目标函数集合;
所述查找模块,还用于在所述目标函数集合中查找与所述目标指令类型对应的目标函数;
处理模块,用于通过所述目标函数对所述报文处理指令进行处理;
所述查找模块,还用于获取所述动态路由中的公共代码逻辑,将所述公共代码逻辑加入第二编译动态库参数;
通过所述第二编译动态库参数对所述公共代码逻辑进行编译,得到配置函数库;
通过所述配置函数库对所述预设动态函数库进行更新,得到目标函数库;
根据所述目标进程信息从目标函数库中查找与所述目标进程信息对应的目标函数集合。
CN201911341649.9A 2019-12-23 2019-12-23 基于动态路由的报文处理方法、设备、存储介质及装置 Active CN111010346B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911341649.9A CN111010346B (zh) 2019-12-23 2019-12-23 基于动态路由的报文处理方法、设备、存储介质及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911341649.9A CN111010346B (zh) 2019-12-23 2019-12-23 基于动态路由的报文处理方法、设备、存储介质及装置

Publications (2)

Publication Number Publication Date
CN111010346A CN111010346A (zh) 2020-04-14
CN111010346B true CN111010346B (zh) 2021-10-19

Family

ID=70117594

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911341649.9A Active CN111010346B (zh) 2019-12-23 2019-12-23 基于动态路由的报文处理方法、设备、存储介质及装置

Country Status (1)

Country Link
CN (1) CN111010346B (zh)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114448791B (zh) * 2021-12-16 2023-08-25 苏州浪潮智能科技有限公司 路由模块的配置方法、装置、电子设备及可读存储介质
CN115580505B (zh) * 2022-09-05 2024-08-06 欣旺达动力科技股份有限公司 报文处理方法、装置、电子设备及计算机可读存储介质

Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2011024A2 (en) * 2006-05-04 2009-01-07 Cisco Technology, Inc. Network element discovery using a network routine protocol
US7861234B1 (en) * 2005-02-23 2010-12-28 Oracle America, Inc. System and method for binary translation to improve parameter passing
CN102595365A (zh) * 2012-03-08 2012-07-18 北京神州数码思特奇信息技术股份有限公司 一种业务组件式开发方法
CN102929716A (zh) * 2012-11-07 2013-02-13 北京亿赛通科技发展有限责任公司 一种启动多进程的方法
CN104950839A (zh) * 2015-04-30 2015-09-30 张陵 一种交换机控制方法及装置
CN105162699A (zh) * 2015-07-31 2015-12-16 广州供电局有限公司 动态路由协议优化方法及系统
CN107465620A (zh) * 2017-08-03 2017-12-12 爱普(福建)科技有限公司 一种通用数据路由器及其通信方法
CN108595218A (zh) * 2018-04-17 2018-09-28 网宿科技股份有限公司 一种加载系统动态库的方法和装置
CN109710671A (zh) * 2018-12-14 2019-05-03 国云科技股份有限公司 实现数据库操作数据引流的方法及其数据库防火墙系统
CN109726067A (zh) * 2017-10-30 2019-05-07 腾讯科技(深圳)有限公司 一种进程监控方法以及客户端设备
CN109840117A (zh) * 2018-06-20 2019-06-04 中兴通讯股份有限公司 训练模型的实现方法、设备以及存储介质
CN110363013A (zh) * 2019-06-29 2019-10-22 苏州浪潮智能科技有限公司 一种Linux系统下在应用层实现文件访问控制的方法与系统

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8775877B2 (en) * 2011-12-28 2014-07-08 Roche Diagnostics Operations, Inc. Dynamic link library integrity checking for handheld medical devices

Patent Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7861234B1 (en) * 2005-02-23 2010-12-28 Oracle America, Inc. System and method for binary translation to improve parameter passing
EP2011024A2 (en) * 2006-05-04 2009-01-07 Cisco Technology, Inc. Network element discovery using a network routine protocol
CN102595365A (zh) * 2012-03-08 2012-07-18 北京神州数码思特奇信息技术股份有限公司 一种业务组件式开发方法
CN102929716A (zh) * 2012-11-07 2013-02-13 北京亿赛通科技发展有限责任公司 一种启动多进程的方法
CN104950839A (zh) * 2015-04-30 2015-09-30 张陵 一种交换机控制方法及装置
CN105162699A (zh) * 2015-07-31 2015-12-16 广州供电局有限公司 动态路由协议优化方法及系统
CN107465620A (zh) * 2017-08-03 2017-12-12 爱普(福建)科技有限公司 一种通用数据路由器及其通信方法
CN109726067A (zh) * 2017-10-30 2019-05-07 腾讯科技(深圳)有限公司 一种进程监控方法以及客户端设备
CN108595218A (zh) * 2018-04-17 2018-09-28 网宿科技股份有限公司 一种加载系统动态库的方法和装置
CN109840117A (zh) * 2018-06-20 2019-06-04 中兴通讯股份有限公司 训练模型的实现方法、设备以及存储介质
CN109710671A (zh) * 2018-12-14 2019-05-03 国云科技股份有限公司 实现数据库操作数据引流的方法及其数据库防火墙系统
CN110363013A (zh) * 2019-06-29 2019-10-22 苏州浪潮智能科技有限公司 一种Linux系统下在应用层实现文件访问控制的方法与系统

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
Integrating Multiple Radio-to-Router Interfaces to Open Source Dynamic Routers;Randy Charland;《IEEE Xplore》;20130128;全文 *
基于嵌入式Linux系统的路由搭建及网络环境模拟;陈丽丽;《CNKI硕士论文全文数据库》;20091231;全文 *

Also Published As

Publication number Publication date
CN111010346A (zh) 2020-04-14

Similar Documents

Publication Publication Date Title
CN110187912B (zh) 一种节点选择方法和装置
CN106209830B (zh) 一种基于xml网络协议表示的报文构造方法
US11184281B2 (en) Packet processing method and apparatus
CN106713004B (zh) 一种路由器适配方法及系统
CN110392002B (zh) 报文处理方法、装置、设备及可读存储介质
CN111010346B (zh) 基于动态路由的报文处理方法、设备、存储介质及装置
CN114500537A (zh) 容器服务的访问方法、系统、存储介质及电子设备
CN113691589B (zh) 报文传输方法、装置及系统
CN110177047B (zh) 报文发送方法、装置、电子设备和计算机可读存储介质
CN114039930B (zh) 数据包处理方法及系统
CN109343970B (zh) 基于应用程序的操作方法、装置、电子设备及计算机介质
CN116233217B (zh) 基于路由的页面跳转方法、装置、电子设备及存储介质
CN108574637B (zh) 一种地址自学习的方法、装置及交换机
CN109257372B (zh) 基于网络融合的报文转发方法、设备、存储介质及装置
CN114253441A (zh) 目标功能的启用方法及装置、存储介质、电子装置
CN110719303B (zh) 一种容器化nrf的方法及系统
CN107992363B (zh) 数据的处理方法和装置
CN117395100B (zh) 网络功能虚拟化网关实现方法、装置、设备及介质
CN113890789B (zh) 适用于数据中心的udp隧道流量的分流方法、流量转发方法
CN113489848B (zh) 一种终端设备测试方法、装置、电子设备及存储介质
US10958558B2 (en) Reactive source routing associated with a network
CN111050339B (zh) 一种基于协议无感知转发的高速数据更新系统及方法
CN117579547A (zh) 报文路由加速方法、装置、主设备及介质
CN113608819A (zh) 创建容器的方法、装置、电子设备及介质
CN118590438A (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