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-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 即可,

Open vSwitch(OVS)是一个开源的虚拟交换机软件,用于实现网络交换功能。它提供了一套灵活的网络转发流量处理机制,并且可以与不同类型的网络虚拟化技术(如OpenStack、KVM等)集成。 OVS-DPDKOVS的一个变种,使用了Data Plane Development Kit(DPDK)来加速数据包处理。DPDK是一个用于快速数据包处理的开源项目,它提供了一组用户空间的库驱动程序,使网络应用程序能够绕过操作系统内核,直接访问网络硬件。通过与DPDK集成,OVS-DPDK可以实现更高的数据包处理性能更低的延迟。 OVS-DPDK具有以下特性: 1. 高性能:使用DPDK加速,可以处理更多的数据包以及更低的延迟。这使得OVS-DPDK非常适合需要高性能的虚拟化环境。 2. 大规模网络:OVS-DPDK支持大规模网络环境,可以处理数十万个虚拟机大量的网络流量。 3. 高级流量管理:OVS-DPDK提供了丰富的流量管理功能,如流量分类、QoS(Quality of Service)、ACL(Access Control List)等,可以根据应用需求对流量进行精细控制管理。 4. 灵活的虚拟化集成:OVS-DPDK可以与不同类型的虚拟化技术(如OpenStack、KVM等)集成,提供灵活的网络虚拟化解决方案。 总之,OVS-DPDK是在传统的OVS基础上加入了DPDK加速技术,以提供更高性能更低延迟的网络转发流量处理能力。这使得它成为虚拟化环境中处理大规模网络流量的理想选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值