OVS 和 OVS-DPDK 对比

本文参考下面这篇论文,只挑取了其中关于 OVS 和 OVS-DPDK 对比的部分进行讲解,更多内容,大家有兴趣可以看论文:
https://networkbuilders.intel.com/docs/open-vswitch-enables-sdn-and-nfv-transformation-paper.pdf

OVS 目前有两种比较突出的架构,一种是原生的 OVS 架构(使用 kernel 作为 datapath),一种是基于 DPDK 的架构(使用用户空间作为 datapath)。

原生 OVS

原生 OVS 架构如下所示,主要包含两个组件:

  • openvswitch.ko :在内核态负责快速路径的数据转发。转发靠流表来完成,每一个流表都包含很多的匹配项(match fields)和相应的动作(actions)

    • match fields : 定义了能够标识一个数据包的头部字段

    • actions : 定义了能够对这个数据包操作的动作,比如添加或去除 VLAN 标签、修改数据包的某个头部字段,以及控制数据包从端口的进出等等。

  • ovs-vswitchd :在用户态负责慢速路径的数据转发。

    • ofproto: 实现 OpenFlow 交换机

    • netdev: 和网络设备(包括物理的和虚拟的)交互的抽象接口层

    • dpif: 用户空间数据转发路径的实现

OVS 和 OVS-DPDK 对比_第1张图片

OVS-DPDK

基于 DPDK 的 OVS 架构如下所示,其中深色部分的模块就是引入 DPDK 相关的模块。

  • dpif-netdev : 用户空间中快速路径的实现,它实现了 dpif  模块 API,可以直接操作 netdev 设备,能够实现数据包在用户空间的快速处理,减少和内核空间的切换开销。

  • ofproto-dpif : 实现了 ofproto 模块 API,直接操作 dpif 层。

  • netdev-dpdk : 使用 DPDK 库实现了 netdev 模块 API,提供了多种类型的接口,如下:

    • Physical ports(PMDs) : 使用 vfio 或者 igb_uio 实现的端口

    • dpdkvhostuser and dpdkvhostcuse: 使用 librte_vhost 库实现的端口,用户可以基于这两种端口类型创建 vhost-uservhost-cuse 端口来完成用户空间的数据转发,并且能够实现和 VM 的快速通信,只要提供 virtio 后端驱动 vhost 即可,virtio/vhost 被证实是用于 VM 通信的一套快速、安全、标准的接口。

    • dpdkr: 使用 librte_ring 实现,用户可以基于这种端口类型创建 dpdk-ring端口来完成用户空间的数据转发,它能够实现和 VM 之间快速的零拷贝通信(使用 IVSHMEM 或者其他进程间通信方式)

OVS 和 OVS-DPDK 对比_第2张图片

两种架构性能对比

那么这两种架构哪种性能更佳呢,不用说,当然是 OVS-DPDK,我们用数据说话,看下下面这份 Intel 做的性能报告(时间是 2015 年,但也具备参考性)。

首先是实验环境参数:

OVS 和 OVS-DPDK 对比_第3张图片

OVS 和 OVS-DPDK 对比_第4张图片

OVS 和 OVS-DPDK 对比_第5张图片

然后看实验拓扑图,包括 physical-to-physicalphysical-to-virtual-to-physical 两种拓扑:

OVS 和 OVS-DPDK 对比_第6张图片

OVS 和 OVS-DPDK 对比_第7张图片

最后再来看性能对比:

同样包括 physical-to-physicalphysical-to-virtual-to-physical 两种场景:

OVS 和 OVS-DPDK 对比_第8张图片

可以看到,P2P 的场景,OVS-DPDK 比原生 OVS 性能提高差不多 12 倍。

OVS 和 OVS-DPDK 对比_第9张图片

对于 PVP 的场景,我们增加单核和多核的实验观察,单核的情况,OVS-DPDK 比原生 OVS 提高 7 倍,双核的情况提高接近 13 倍。

基于 DPDK 的 VNF 使用 OVS 作为数据面

基于 OVS-DPDK 的 VNF 架构如下图所示:

OVS 和 OVS-DPDK 对比_第10张图片

DPDK 在其中既加速 OVS 数据平面,又加速 VNF 应用,这种方案由于采用纯软件的形式实现,可编程灵活,DPDK 的参与也使得性能大大提高,基本可以媲美纯硬件的形式。


后台回复“加群”,带你进入高手如云交流群

推荐阅读:

微软出品的最新K8S学习指南3.0下载

了解HTTPS工作原理,看这一篇就够了

值得收藏的14个Linux下CPU监控工具

Linux 硬盘结构长啥样,了解一下

谨慎使用的 Linux 命令

史上最硬核的Linux依赖问题解决方案

一文搞懂HTTP+TCP的长连接和短连接

正确理解CPU使用率和平均负载的关系

和面试官之间关于操作系统的一场对弈

Linux 系统 UDP 丢包问题分析思路

如何拥有一台属于自己的私有云!

晋升、面试中绕不开的性能优化问题
史上最全Linux面试题(2020最新版)

什么是物联网?这里有你需要了解的一切

Kubernetes的架构为什么是这个样的?

任何人都能看得懂的网络协议之ARP


喜欢,就给我一个“在看”


10T 技术资源大放送!包括但不限于:云计算、虚拟化、微服务、大数据、网络、Linux、Docker、Kubernetes、Python、Go、C/C++、Shell、PPT 等。在公众号内回复「1024,即可免费获取!!

你可能感兴趣的:(OVS 和 OVS-DPDK 对比)