CN113553137B - 一种nfv架构下基于dpdk的接入能力网元高速数据处理方法 - Google Patents
一种nfv架构下基于dpdk的接入能力网元高速数据处理方法 Download PDFInfo
- Publication number
- CN113553137B CN113553137B CN202110674581.7A CN202110674581A CN113553137B CN 113553137 B CN113553137 B CN 113553137B CN 202110674581 A CN202110674581 A CN 202110674581A CN 113553137 B CN113553137 B CN 113553137B
- Authority
- CN
- China
- Prior art keywords
- data packet
- queue
- core
- network
- dpdk
- 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 claims abstract description 12
- 238000000034 method Methods 0.000 claims abstract description 12
- 238000012545 processing Methods 0.000 claims abstract description 12
- 230000005540 biological transmission Effects 0.000 claims abstract description 4
- 230000006870 function Effects 0.000 claims description 10
- 238000005516 engineering process Methods 0.000 claims description 7
- 238000004458 analytical method Methods 0.000 claims description 2
- 230000008569 process Effects 0.000 description 5
- 238000004891 communication Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000002457 bidirectional effect Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 238000013468 resource allocation Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/4557—Distribution of virtual machine instances; Migration and load balancing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45595—Network integration; Enabling network access in virtual machine instances
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明提供一种NFV架构下基于DPDK的接入能力网元高速数据处理方法。该方法包括:步骤1:配置I/O透传方式的虚拟主机接口;步骤2:加载VFIO和VFIO‑PCI驱动,分配内存挂载巨页,绑定网卡然后启动虚拟机;步骤3:设置网口、队列和逻辑核对应关系;所述逻辑核分为I/O核和Worker核;步骤4:网卡的RSS驱动接收数据包并将其分发到对应的队列,以供该队列所绑定的I/O核对其进行处理;步骤5:I/O核采用负载均衡算法再将数据包分配到不同的Worker核上;步骤6:Worker核接到数据包后先对数据包进行解析,然后查表判断该数据包是否应该丢弃,若为有效数据包,则接着判断该数据包应转发至哪个网口并送入该网口的发送队列。
Description
技术领域
本发明涉及通信网安全防护技术领域,尤其涉及一种NFV架构下基于DPDK的接入能力网元高速数据处理方法。
背景技术
随着通信技术的发展和业务种类的丰富,5G、IMS网络逐渐向IP化、扁平化的方向演进,主流运营商为了降低成本、实现业务快速部署和灵活化资源配置,普遍选择使用网络虚拟化技术(NFV)。然而这样则会面临新的问题,一方面,虽然NFV的数据包收发过程与传统网络架构处理流程基本一致,但虚拟化会造成设备接入处理能力下降;另一方面,带宽越来越大,业务承载数据体量越来越高,需要接入处理的流量呈现指数级增加。因此,面向5G、IMS网络的安全防护系统需要对高速接入数据进行监测处理。
发明内容
针对现有的面向5G、IMS网络的数据处理方法存在数据处理能力较低的问题,本发明提供一种NFV架构下基于DPDK的接入能力网元高速数据处理方法,能有效提高安全防护系统在虚拟环境下对高速接入数据的转发效率和业务处理性能。
本发明提供一种NFV架构下基于DPDK的接入能力网元高速数据处理方法,包括:
步骤1:配置I/O透传方式的虚拟机接口;
步骤2:加载VFIO和VFIO-PCI驱动,分配内存挂载巨页,绑定网卡然后启动虚拟机;
步骤3:设置网口、队列和逻辑核对应关系;所述逻辑核分为I/O核和Worker核;
步骤4:网卡的RSS驱动接收数据包并将其分发到对应的队列,以供该队列所绑定的I/O核对其进行处理;
步骤5:I/O核采用负载均衡算法再将数据包分配到不同的Worker核上;
步骤6:Worker核接到数据包后先对数据包进行解析,然后查表判断该数据包是否应该丢弃,若为有效数据包,则接着判断该数据包应转发至哪个网口并送入该网口的发送队列。
进一步地,步骤1具体包括:
采用SR-IOV技术,通过PCIe总线多路复用将一个物理网卡分成多个VF。
进一步地,步骤3具体包括:
为连接线路侧的第一网口配置m个接收队列和m个发送队列;为连接业务侧的第二网口配置m个接收队列和m个发送队列;其中,每个所述接收队列和发送队列均从0开始编号;
将两个网口编号相同的接收队列和发送队列绑定至同一个逻辑核。
进一步地,步骤4具体包括:
网卡的RSS驱动接收数据包,获取所述数据包的源IP地址、目的IP地址和协议信息;
根据源IP地址、目的IP地址和协议信息通过配置的哈希函数计算出哈希值,取哈希值的低n位作为RETA的索引,根据RETA存储的值分发到对应的接收队列。
进一步地,所述配置的哈希函数为RSS对称哈希算法。
本发明的有益效果:
本发明直接把物理设备分配给虚拟机使用的方式,能使虚拟机获得近乎本地的性能,并且CPU开销不高;并且通过引入SR-IOV技术可以解决一台物理设备赋予多个虚拟机时物理网卡不足的问题;通过引入DPDK技术极大提高了数据接入能力以及数据处理效率。
附图说明
图1为本发明实施例提供的一种NFV架构下基于DPDK的接入能力网元高速数据处理方法的流程图;
图2为本发明实施例提供的虚拟主机接口实现方式图;
图3为本发明实施例提供的DPDK在负载均衡模式下过滤分发报文的逻辑图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
如图1所示,本发明实施例提供一种NFV架构下基于DPDK的接入能力网元高速数据处理方法,包括以下步骤:
S101:配置I/O透传方式的虚拟机接口;
具体地,如图2所示,采用SR-IOV技术,通过PCIe总线多路复用将一个物理网卡分成多个VF。在NFV架构下,物理设备上的网络功能同硬件剥离,以软件化的VNF(virtualnetworkfunction,虚拟网络功能)形式运行,从而实现网络设备形态的通用化,方便设备功能灵活扩展。在图2中, VNF部署在虚拟机中,为了进一步优化虚拟机内部I/O性能,可以让DPDK接管网卡I/O驱动,这样VNF可以绕过Linux内核网络协议栈,通过调用DPDK的用户态API进行快速转发。
在实际应用中,具体操作为:在BIOS打开VT-D和SR-IOV支持选项,然后进入ESXi硬件配置页面,找到需要进行配置的SR-IOV网卡,配置完成后重新启动ESXi。
本发明实施例中的直接把物理设备分配给虚拟机使用的方式,能使虚拟机获得近乎本地的性能,并且CPU开销不高;并且通过引入SR-IOV技术可以解决一台物理设备赋予多个虚拟机时物理网卡不足的问题。
S102:加载VFIO和VFIO-PCI驱动,分配内存挂载巨页,绑定网卡然后启动虚拟机;
S103:设置网口、队列和逻辑核对应关系;所述逻辑核分为I/O核和Worker核;
具体地,使用该方法的系统包括两个网口:连接线路侧的第一网口和连接业务侧的第二网口。队列类型分为发送队列和接收队列。为连接线路侧的第一网口配置m个接收队列和m个发送队列;为连接业务侧的第二网口配置m个接收队列和m个发送队列;其中,每个所述接收队列和发送队列均均从0开始编号;将两个网口编号相同的接收队列和发送队列绑定至同一个逻辑核。
例如,如图3所示,使用该数据处理方法的系统一共有两个网口(即网口0(port0)和网口1(port1)),一个连接线路侧一个连接业务侧,为每个网口分别配置四个接收队列和四个发送队列,绑定在四个I/O核上。例如,对于I/O核Lcore 0来说,该I/O核上共有四个队列,分别是网口0的接收队列0、发送队列0和网口1的接收队列0、发送队列0;对于I/O核Lcore 1来说,该I/O核上共有四个队列,分别是网口0的接收队列1、发送队列1和网口1的接收队列1、发送队列1;以此类推可知I/O核Lcore 2和I/O核Lcore3所绑定的接收队列和发送队列。
本发明实施例中的上述队列配置方式能够更好地配合RSS对称算法,使得双向同源数据包可以分配到同一个逻辑核上进行处理。
S104:网卡的RSS驱动接收数据包并将其分发到对应的队列,以供该队列所绑定的I/O核对其进行处理;
具体地,网卡的RSS驱动接收数据包,获取所述数据包的源IP地址、目的IP地址和协议信息;根据源IP地址、目的IP地址和协议信息通过配置的哈希函数计算出哈希值,取哈希值的低n位作为RETA(redirection table)的索引,根据RETA存储的值分发到对应的接收队列,以便该接收队列所绑定的I/O核对数据包进行处理。RETA(redirection table):表示重定向表。
作为一种可实施方式,为了使对称信息的数据包在同一个逻辑核上处理,从而提高性能,此处选择的哈希函数为RSS对称哈希算法。
S105:I/O核采用负载均衡算法再将数据包分配到不同的Worker核上;
具体地,本发明实施例一共使用了8个逻辑核,其中四个逻辑核被称作“I/O核”,每个“I/O核”绑定两个网口的接收和发送队列(共四个),从而实现数据接入和转发;另外四个称作“Worker核”,用来解析处理数据包。这个过程就像流水线工作一样,网口现对接收到的数据包通过RSS对称哈希算法将数据包分配到不同的“I/O核”上,这样当数据量大的时候可以提高数据接入转发效率,这是第一层负载均衡;然后“I/O核”再根据数据包的源IP地址、目的IP地址和协议信息采用三元哈希算法计算得到哈希值将该数据包分配到不同Worker逻辑核上进行解析处理,且同源同宿,这是第二次负载均衡。
S106:Worker核接到数据包后先对数据包进行解析,然后查表判断该数据包是否应该丢弃,若为有效数据包,则接着判断该数据包应转发至哪个网口并送入该网口的发送队列。
具体地,该步骤中所查询的表由5G、IMS网络安全防护系统的控制模块进行维护。
本发明主要针对在网络功能虚拟化(NFV)情况下高速接入网元提高业务处理性能相关的场景,提供了一种面向5G、IMS网络的基于DPDK的高速数据处理方法。
最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。
Claims (2)
1.一种NFV架构下基于DPDK的接入能力网元高速数据处理方法,其特征在于,包括:
步骤1:配置I/O透传方式的虚拟机接口;具体包括:采用SR-IOV技术,通过PCIe总线多路复用将一个物理网卡分成多个VF;采用DPDK接管网卡I/O驱动使得部署在虚拟机中的VNF可以绕过Linux内核网络协议栈,通过调用DPDK的用户态API进行快速转发;
步骤2:加载VFIO和VFIO-PCI驱动,分配内存挂载巨页,绑定网卡然后启动虚拟机;
步骤3:设置网口、队列和逻辑核对应关系;所述逻辑核分为I/O核和Worker核;具体包括:为连接线路侧的第一网口配置m个接收队列和m个发送队列;为连接业务侧的第二网口配置m个接收队列和m个发送队列;其中,每个所述接收队列和发送队列均从0开始编号;将两个网口编号相同的接收队列和发送队列绑定至同一个逻辑核;
步骤4:网卡的RSS驱动接收数据包并将其分发到对应的队列,以供该队列所绑定的I/O核对其进行处理;具体包括:网卡的RSS驱动接收数据包,获取所述数据包的源IP地址、目的IP地址和协议信息;根据源IP地址、目的IP地址和协议信息通过配置的哈希函数计算出哈希值,取哈希值的低n位作为RETA的索引,根据RETA存储的值分发到对应的接收队列;RETA指重定向表;
步骤5:I/O核采用负载均衡算法再将数据包分配到不同的Worker核上;具体包括:I/O核根据数据包的源IP地址、目的IP地址和协议信息采用三元哈希算法计算得到哈希值将该数据包分配到不同Worker逻辑核上进行解析处理,且同源同宿;
步骤6:Worker核接到数据包后先对数据包进行解析,然后查表判断该数据包是否应该丢弃,若为有效数据包,则接着判断该数据包应转发至哪个网口并送入该网口的发送队列。
2.根据权利要求1所述的接入能力网元高速数据处理方法,其特征在于,所述配置的哈希函数为RSS对称哈希算法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110674581.7A CN113553137B (zh) | 2021-06-17 | 2021-06-17 | 一种nfv架构下基于dpdk的接入能力网元高速数据处理方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110674581.7A CN113553137B (zh) | 2021-06-17 | 2021-06-17 | 一种nfv架构下基于dpdk的接入能力网元高速数据处理方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113553137A CN113553137A (zh) | 2021-10-26 |
CN113553137B true CN113553137B (zh) | 2022-11-01 |
Family
ID=78130618
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110674581.7A Active CN113553137B (zh) | 2021-06-17 | 2021-06-17 | 一种nfv架构下基于dpdk的接入能力网元高速数据处理方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113553137B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114301808B (zh) * | 2021-12-23 | 2023-11-10 | 北京集智达智能科技有限责任公司 | 基于dpdk技术的x86平台网口性能测试方法及装置 |
CN114710811B (zh) * | 2022-04-07 | 2024-10-01 | 中国联合网络通信集团有限公司 | 数据流转发方法、装置、电子设备及存储介质 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106294169A (zh) * | 2016-08-17 | 2017-01-04 | 华中科技大学 | 一种基于符号执行虚拟机的数据竞争检测与重放方法 |
CN107147517A (zh) * | 2017-03-24 | 2017-09-08 | 上海交通大学 | 一种针对虚拟网络功能的自适应计算资源分配方法 |
WO2017152633A1 (zh) * | 2016-03-09 | 2017-09-14 | 中兴通讯股份有限公司 | 一种端口绑定实现方法及装置 |
CN109739618A (zh) * | 2018-12-10 | 2019-05-10 | 新华三云计算技术有限公司 | 虚拟机迁移方法及装置 |
CN110636139A (zh) * | 2019-10-15 | 2019-12-31 | 广州市品高软件股份有限公司 | 一种云负载均衡的优化方法及系统 |
CN111953706A (zh) * | 2020-08-21 | 2020-11-17 | 公安部第三研究所 | 基于https流量信息识别移动应用的方法 |
CN112148421A (zh) * | 2019-06-29 | 2020-12-29 | 华为技术有限公司 | 虚拟机迁移的方法以及装置 |
CN112398687A (zh) * | 2020-11-13 | 2021-02-23 | 广东省华南技术转移中心有限公司 | 云计算网络的配置方法、云计算网络系统以及存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20180173547A1 (en) * | 2016-12-20 | 2018-06-21 | Intel Corporation | Pinning of virtual network function (vnf) deployments using hardware metrics |
-
2021
- 2021-06-17 CN CN202110674581.7A patent/CN113553137B/zh active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2017152633A1 (zh) * | 2016-03-09 | 2017-09-14 | 中兴通讯股份有限公司 | 一种端口绑定实现方法及装置 |
CN106294169A (zh) * | 2016-08-17 | 2017-01-04 | 华中科技大学 | 一种基于符号执行虚拟机的数据竞争检测与重放方法 |
CN107147517A (zh) * | 2017-03-24 | 2017-09-08 | 上海交通大学 | 一种针对虚拟网络功能的自适应计算资源分配方法 |
CN109739618A (zh) * | 2018-12-10 | 2019-05-10 | 新华三云计算技术有限公司 | 虚拟机迁移方法及装置 |
CN112148421A (zh) * | 2019-06-29 | 2020-12-29 | 华为技术有限公司 | 虚拟机迁移的方法以及装置 |
CN110636139A (zh) * | 2019-10-15 | 2019-12-31 | 广州市品高软件股份有限公司 | 一种云负载均衡的优化方法及系统 |
CN111953706A (zh) * | 2020-08-21 | 2020-11-17 | 公安部第三研究所 | 基于https流量信息识别移动应用的方法 |
CN112398687A (zh) * | 2020-11-13 | 2021-02-23 | 广东省华南技术转移中心有限公司 | 云计算网络的配置方法、云计算网络系统以及存储介质 |
Non-Patent Citations (6)
Title |
---|
A Method for Performance Optimization of Virtual Network I/O Based on DPDK-SRIOV;Hanji Shen等;《2018 IEEE International Conference on Information and Automation (ICIA)》;20190826;全文 * |
DPDK技术应用研究综述;曾理等;《网络新媒体技术》;20200430;第9卷(第2期);全文 * |
Intra-Node Resource Isolation for SFC with SR-IOV;Simon Bauer等;《2018 IEEE 7th International Conference on Cloud Networking (CloudNet)》;20181129;全文 * |
SR-IOV技术在OpenStack中的应用;张驰等;《计算机系统应用》;20170915(第09期);全文 * |
基于可编程硬件的有状态网络功能硬件加速架构;兰天翼等;《电子学报》;20180715(第07期);全文 * |
智能网卡应用于云网络加速方案研究;刘畅等;《电信工程技术与标准化》;20200811(第08期);全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN113553137A (zh) | 2021-10-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3629162B1 (en) | Technologies for control plane separation at a network interface controller | |
CN113934660B (zh) | 加速网络分组处理 | |
US8005022B2 (en) | Host operating system bypass for packets destined for a virtual machine | |
US7983257B2 (en) | Hardware switch for hypervisors and blade servers | |
US8660133B2 (en) | Techniques to utilize queues for network interface devices | |
CN113553137B (zh) | 一种nfv架构下基于dpdk的接入能力网元高速数据处理方法 | |
US20100128605A1 (en) | Method and system for controlling traffic over a computer network | |
CN106557444B (zh) | 实现sr-iov网卡的方法和装置、实现动态迁移的方法和装置 | |
US20040037313A1 (en) | Packet data service over hyper transport link(s) | |
CN110636139B (zh) | 一种云负载均衡的优化方法及系统 | |
EP2880828A1 (en) | System and method for virtual ethernet interface binding | |
CN102263698B (zh) | 虚拟通道的建立方法、数据传输的方法及线卡 | |
JP2014509427A (ja) | Pciエクスプレス・マルチプル・ルートi/o仮想化環境における低待ち時間の優先順位付け | |
US8902731B2 (en) | Method, network card, and communication system for binding physical network ports | |
CN108768667B (zh) | 一种用于多核处理器片内核间网络通信的方法 | |
US11343176B2 (en) | Interconnect address based QoS regulation | |
US10007625B2 (en) | Resource allocation by virtual channel management and bus multiplexing | |
US7088719B2 (en) | Processor with packet processing order maintenance based on packet flow identifiers | |
CN112769905A (zh) | 一种基于numa架构的飞腾平台下高性能网卡性能优化方法 | |
CN115412502B (zh) | 一种网络端口扩展和报文快速均衡处理方法 | |
JP2014187430A (ja) | 通信システム、中継装置、通信方法、及びプログラム | |
JP2000235536A (ja) | データ通信方式及び装置 | |
US7113518B2 (en) | Processor with reduced memory requirements for high-speed routing and switching of packets | |
CN113535370A (zh) | 一种实现负载均衡的多rdma网卡虚拟化的方法、设备 | |
EP4156765A1 (en) | Microwave data processing method, apparatus, and device |
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 | ||
CP03 | Change of name, title or address |
Address after: 450000 Science Avenue 62, Zhengzhou High-tech Zone, Henan Province Patentee after: Information Engineering University of the Chinese People's Liberation Army Cyberspace Force Country or region after: China Address before: No. 62 Science Avenue, High tech Zone, Zhengzhou City, Henan Province Patentee before: Information Engineering University of Strategic Support Force,PLA Country or region before: China |