0

0

NFV中:DPDK与SR-IOV应用场景及性能对比

絕刀狂花

絕刀狂花

发布时间:2025-07-14 09:30:17

|

319人浏览过

|

来源于php中文网

原创

nfv中:dpdk与sr-iov应用场景及性能对比关于作者

作者简介:

张帅,Wechat:yorkszhang

网站:www.flowlet.net

DPDK和SR-IOV目前主要用于提升IDC(数据中心)中的网络数据包处理速度。然而,在NFV(网络功能虚拟化)场景下,DPDK与SR-IOV各自的应用场景和优缺点是什么呢?本文将从以下几个方面来探讨这个问题:

1、什么是DPDK?

2、什么是SR-IOV?

3、DPDK与SR-IOV有何不同?

4、DPDK与SR-IOV各自适合的应用场景是怎样的?

1、什么是DPDK?

NFV中:DPDK与SR-IOV应用场景及性能对比DPDK(Data Plane Development Kit)是由6Wind和Intel开发的高性能数据平面开发工具包。为了更好地理解DPDK,我们先来看看Linux内核是如何处理网络数据包的。

NFV中:DPDK与SR-IOV应用场景及性能对比图1 左:Linux kernel 右:DPDK

在默认情况下,Linux使用内核来处理网络数据包。随着IDC(数据中心)中NIC速率从40G逐步提升到目前主流的100G,未来将进一步升级到400G,Linux内核已不再适合处理高速网络。

内核的缺点:

1、中断处理:当大量网络数据包到达时,会频繁触发中断请求,导致高性能开销和上下文切换延迟。

2、内存拷贝:网络数据包到达时,网卡通过DMA等方式拷贝到内核缓冲区,内核协议栈再从内核空间拷贝到用户态空间,这个过程在Linux内核协议栈中占用了数据包处理流程的57.1%。

3、局部性失效:当前主流处理器包含多个CPU核心,这意味着一个数据包的处理可能跨多个CPU核心。例如,一个数据包可能在cpu0中断,内核态处理在cpu1,用户态处理在cpu2,这种跨核心处理容易导致CPU缓存失效,引发局部性失效。

DPDK的优点:

从前面的分析可以看出,目前网络IO实现方式中,内核是性能瓶颈的根源。为了解决性能问题,需要绕过内核,直接在用户态收发数据包。

1、内核绕过:通过UIO(Userspace I/O)旁路数据包,实现用户态数据包收发,减少上下文切换和内存拷贝。

2、使用多核编程代替多线程编程:设置CPU的亲和性,将线程和CPU核进行一对一绑定,减少彼此之间的调度切换。

3、使用大页内存代替普通内存:减少cache-miss。

4、采用无锁技术:解决资源竞争问题。

2、带有OVS的DPDK

NFV中:DPDK与SR-IOV应用场景及性能对比什么是OVS?

OVS(Open vSwitch)是一款高质量的开源虚拟交换机,运行在hypervisor中,为虚拟机提供虚拟网络。

NFV中:DPDK与SR-IOV应用场景及性能对比图2 NVF中OVS所处位置

OVS是实施VNF(Virtual Network Function)的一部分,位于hypervisor中,如图2所示,流量可以从一个VNF通过OVS传递到另一个VNF中。

OVS的转发平面是内核的一部分,无论OVS有多好,它都面临着与前面讨论的Linux网络协议栈相同的问题。

沁言学术
沁言学术

你的论文写作AI助理,永久免费文献管理工具,认准沁言学术

下载

OVS+DPDK

NFV中:DPDK与SR-IOV应用场景及性能对比图3 左:Kernel+OVS 右:DPDK+OVS

如图3所示:基于DPDK的转发路径替换标准的OVS内核转发路径,在主机上创建一个用户空间vSwitch,它完全运行在用户空间中,从而提高了OVS交换机的性能。

3、SR-IOV

NFV中:DPDK与SR-IOV应用场景及性能对比在讲述SR-IOV之前,我们先讲述一下PCI直通技术。

什么是PCI直通?

PCI直通:不使用hypervisor也可以向虚拟机提供完整的网卡。虚拟机认为自己与网卡直接相连。如图4所示,有两个NIC卡和两个VNF,每个都独占访问其中一个NIC卡。

NFV中:DPDK与SR-IOV应用场景及性能对比图4 网卡直通

PCI直通的缺点:由于下面的两个网卡被VNF1和VNF3独占,并且没有第三个专用网卡分配给VNF2使用。

什么是SR-IOV?

SR-IOV(Single Root I/O Virtualization)规范:定义了一种用于虚拟化PCIe设备的机制。这种机制可以将单个PCIe以太网控制器虚拟化为多个PCIe设备。

NFV中:DPDK与SR-IOV应用场景及性能对比图5 SR-IOV

通过创建PCIe设备的VF,每个VF可以分配给单个VM/VNF,从而消除由于网卡不够的问题。

4、DPDK vs SR-IOV

NFV中:DPDK与SR-IOV应用场景及性能对比数据中心中存在东西向流量与南北向流量。

NFV中:DPDK与SR-IOV应用场景及性能对比图6

在同一服务器内的东西向流量中,DPDK的性能优于SR-IOV。这很容易理解:如果流量是在服务器内部路由/交换的,而不是到NIC,SR-IOV没有任何优势。相反,SR-IOV会成为一个瓶颈(流量路径会变长,网卡资源会被占用)。

NFV中:DPDK与SR-IOV应用场景及性能对比图7

图7为Intel官方给出东西向流量场景下DPDK与SR-IOV的性能测试数据。

在南北向流量(也包括从一个服务器到另一个服务器的东西向流量)场景中,SR-IOV的性能优于DPDK。

NFV中:DPDK与SR-IOV应用场景及性能对比图8

NFV中:DPDK与SR-IOV应用场景及性能对比图9

图9为Intel官方给出南北向流量场景下DPDK与SR-IOV的性能测试数据。

end

| 温馨提示 |

欢迎分享、收藏、点赞、转发。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

481

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

478

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1349

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

703

2023.06.29

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

0

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 8.9万人学习

Rust 教程
Rust 教程

共28课时 | 4.6万人学习

Vue 教程
Vue 教程

共42课时 | 6.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号