dpdk安装及示例程序使用指南(虚拟机版)

合集下载

dpdk工作原理

dpdk工作原理

dpdk工作原理DPDK(Data Plane Development Kit)是一个用于数据包处理的开源工具集。

它的设计目标是提供一个高效灵活的网络数据包处理框架,以加速数据包处理应用程序的性能。

DPDK的工作原理可以概括为以下几个关键步骤:1. 初始化:应用程序通过调用DPDK提供的初始化函数来初始化环境。

这包括创建内存池、设置物理地址转换、配置核间通信等。

2. 配置:应用程序将网络设备绑定到DPDK的驱动程序上,以便DPDK可以直接访问网络设备的物理资源。

此外,还需要配置网络设备和队列的属性,如队列大小、数目、RSS配置等。

3. 启动:应用程序启动DPDK的运行时环境,并绑定每个逻辑核心到指定的物理核心。

这样可以确保数据包处理在指定的核心上执行,避免了多核心之间的上下文切换开销。

4. 接收:DPDK使用轮询模式或中断模式从网络设备接收数据包。

在轮询模式下,每个逻辑核心定期检查网络设备的接收队列,将接收到的数据包复制到应用程序的缓冲区。

在中断模式下,网络设备将接收到的数据包触发中断,逻辑核心在中断处理程序中将数据包复制到缓冲区。

5. 数据包处理:应用程序通过DPDK提供的数据包处理函数对接收到的数据包进行处理。

这包括解析数据包头部、查找路由表、执行策略等操作。

6. 发送:应用程序通过调用DPDK的数据包发送函数将处理后的数据包发送回网络设备。

DPDK会将数据包复制到发送队列,并通知网络设备发送数据包。

7. 结束:在应用程序完成数据包处理后,可以调用DPDK提供的清理函数来关闭网络设备、释放资源等。

这样可以确保环境的恢复和系统的稳定。

DPDK的工作原理基于用户空间的数据包处理模式,通过绕过操作系统内核,直接访问网络设备和物理资源,从而避免了操作系统内核的开销和限制。

这使得DPDK能够实现高效的数据包处理,提升网络应用程序的性能。

openstack ovs-dpdk原理

openstack ovs-dpdk原理

openstack ovs-dpdk原理OpenStack OVS-DPDK原理OpenStack是目前最流行的开源云计算管理平台之一,它提供了云计算中常见的计算、网络、存储等服务,可以帮助用户快速搭建自己的云计算环境。

而Open Virtual Switch (OVS)是OpenStack中常用的网络虚拟化技术,可以为VM (虚拟机)提供灵活的网络服务,同时保证了数据的安全性和可靠性。

而DPDK (Data Plane Development Kit)是Intel提供的一款数据平面开发工具包,可以帮助开发者实现高性能数据处理的应用程序。

本文主要介绍OpenStack OVS-DPDK原理,包括OVS和DPDK的概念、OVS-DPDK的架构、OVS-DPDK的工作原理以及如何配置使用OVS-DPDK等方面。

1. OVS和DPDK概念1.1 OVSOpen vSwitch(OVS)是一款开源的虚拟交换机,可以在虚拟机之间提供流量控制、QoS、负载均衡等网络功能。

OVS是使用C语言编写的,支持多种协议,例如VXLAN、GRE、STT、IPsec等。

OVS以插件的方式与OpenStack集成,并且可以与其他虚拟化软件和硬件配合使用,例如QEMU、XEN、DPDK等。

1.2 DPDKData Plane Development Kit(DPDK)是一个数据平面开发工具包,可以帮助开发者实现高性能数据处理的应用程序。

DPDK运行在x86、ARM和Power8等平台上,使用用户空间设备驱动程序(User Space Device Driver)和高效率的队列管理,可以在不使用内核网络协议栈的情况下,实现高速数据包的收发和处理。

2. OVS-DPDK架构OVS-DPDK是将OVS和DPDK结合起来实现的一种高性能的数据平面虚拟化技术。

OVS-DPDK的架构如图1所示:图1 OVS-DPDK架构从图1中可以看出,OVS-DPDK的架构由三部分组成,分别是:1. 用户态进程(OVS-DPDK)。

NVIDIA DOCA DPDK MLNX-15-060464 编程指南说明书

NVIDIA DOCA DPDK MLNX-15-060464 编程指南说明书

Programming GuideTable of Contents Chapter 1. Reference (1)Chapter 1.ReferencePlease refer to DPDK's official programmer's guide for programming guidance as well as relevant BlueField platform and DPDK driver information.NoticeThis document is provided for information purposes only and shall not be regarded as a warranty of a certain functionality, condition, or quality of a product. NVIDIA Corporation nor any of its direct or indirect subsidiaries and affiliates (collectively: “NVIDIA”) make no representations or warranties, expressed or implied, as to the accuracy or completeness of the information contained in this document and assume no responsibility for any errors contained herein. NVIDIA shall have no liability for the consequences or use of such information or for any infringement of patents or other rights of third parties that may result from its use. This document is not a commitment to develop, release, or deliver any Material (defined below), code, or functionality.NVIDIA reserves the right to make corrections, modifications, enhancements, improvements, and any other changes to this document, at any time without notice. Customer should obtain the latest relevant information before placing orders and should verify that such information is current and complete.NVIDIA products are sold subject to the NVIDIA standard terms and conditions of sale supplied at the time of order acknowledgement, unless otherwise agreed in an individual sales agreement signed by authorized representatives of NVIDIA and customer (“Terms of Sale”). NVIDIA hereby expressly objects to applying any customer general terms and conditions with regards to the purchase of the NVIDIA product referenced in this document. No contractual obligations are formed either directly or indirectly by this document.NVIDIA products are not designed, authorized, or warranted to be suitable for use in medical, military, aircraft, space, or life support equipment, nor in applications where failure or malfunction of the NVIDIA product can reasonably be expected to result in personal injury, death, or property or environmental damage. NVIDIA accepts no liability for inclusion and/or use of NVIDIA products in such equipment or applications and therefore such inclusion and/or use is at customer’s own risk. NVIDIA makes no representation or warranty that products based on this document will be suitable for any specified use. Testing of all parameters of each product is not necessarily performed by NVIDIA. It is customer’s sole responsibility to evaluate and determine the applicability of any information contained in this document, ensure the product is suitable and fit for the application planned by customer, and perform the necessary testing for the application in order to avoid a default of the application or the product. Weaknesses in customer’s product designs may affect the quality and reliability of the NVIDIA product and may result in additional or different conditions and/or requirements beyond those contained in this document. NVIDIA accepts no liability related to any default, damage, costs, or problem which may be based on or attributable to: (i) the use of the NVIDIA product in any manner that is contrary to this document or (ii) customer product designs.No license, either expressed or implied, is granted under any NVIDIA patent right, copyright, or other NVIDIA intellectual property right under this document. Information published by NVIDIA regarding third-party products or services does not constitute a license from NVIDIA to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property rights of the third party, or a license from NVIDIA under the patents or other intellectual property rights of NVIDIA.Reproduction of information in this document is permissible only if approved in advance by NVIDIA in writing, reproduced without alteration and in full compliance with all applicable export laws and regulations, and accompanied by all associated conditions, limitations, and notices.THIS DOCUMENT AND ALL NVIDIA DESIGN SPECIFICATIONS, REFERENCE BOARDS, FILES, DRAWINGS, DIAGNOSTICS, LISTS, AND OTHER DOCUMENTS (TOGETHER AND SEPARATELY, “MATERIALS”) ARE BEING PROVIDED “AS IS.” NVIDIA MAKES NO WARRANTIES, EXPRESSED, IMPLIED, STATUTORY, OR OTHERWISE WITH RESPECT TO THE MATERIALS, AND EXPRESSLY DISCLAIMS ALL IMPLIED WARRANTIES OF NONINFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE. TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL NVIDIA BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF NVIDIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. Notwithstanding any damages that customer might incur for any reason whatsoever, NVIDIA’s aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms of Sale for the product.TrademarksNVIDIA, the NVIDIA logo, and Mellanox are trademarks and/or registered trademarks of Mellanox Technologies Ltd. and/or NVIDIA Corporation in the U.S. and in other countries. Other company and product names may be trademarks of the respective companies with which they are associated.Copyright© 2021 NVIDIA Corporation & affiliates. All rights reserved.NVIDIA Corporation | 2788 San Tomas Expressway, Santa Clara, CA 95051。

dpdk安装及示例程序使用指南(虚拟机版)

dpdk安装及示例程序使用指南(虚拟机版)

DPDK安装及示例程序使用指南(适用于虚拟机)--torronto 2016.1.27 关于dpdk的介绍不用多说,主要就是它是intel开发的一个网络数据包查找转发的套件,用以分析网络数据的,所以只支持intel的网卡以及极少数除intel之外的网卡,具体支持的型号,官网有说明。

因此,大多数时候,我们都是用虚拟机来仿真。

1.在虚拟机中的ubuntu系统上手动设置2个网卡(一共3个),就使用默认的桥接模式,然后修改处理器个数为2个处理器,每个处理器2核心。

内存分配,1GB以上,2GB更好。

2.去官网下载dpdk软件包,http://www.dpdk.eu/download3.将软件包解压在主目录下,根据个人喜好,因为后面编译和使用示例每次都要访问的。

4.从终端进入5.tools文件夹中有一个setup.sh方便新手完成dpdk的设置初始化操作:(当然,配置编译之前先进入特权模式)6.我们可以看到setup.sh里的一些选项如下:------------------------------------------------------------------------------RTE_SDK exported as /home/torronto/dpdk-2.2.0----------------------------------------------------------------------------------------------------------------------------------------Step 1: Select the DPDK environment to build----------------------------------------------------------[1] arm64-armv8a-linuxapp-gcc[2] arm64-thunderx-linuxapp-gcc[3] arm64-xgene1-linuxapp-gcc[4] arm-armv7a-linuxapp-gcc[5] i686-native-linuxapp-gcc[6] i686-native-linuxapp-icc[7] ppc_64-power8-linuxapp-gcc[8] tile-tilegx-linuxapp-gcc[9] x86_64-ivshmem-linuxapp-gcc[10] x86_64-ivshmem-linuxapp-icc[11] x86_64-native-bsdapp-clang[12] x86_64-native-bsdapp-gcc[13] x86_64-native-linuxapp-clang[14] x86_64-native-linuxapp-gcc[15] x86_64-native-linuxapp-icc[16] x86_x32-native-linuxapp-gcc----------------------------------------------------------Step 2: Setup linuxapp environment----------------------------------------------------------[17] Insert IGB UIO module[18] Insert VFIO module[19] Insert KNI module[20] Setup hugepage mappings for non-NUMA systems[21] Setup hugepage mappings for NUMA systems[22] Display current Ethernet device settings[23] Bind Ethernet device to IGB UIO module[24] Bind Ethernet device to VFIO module[25] Setup VFIO permissions----------------------------------------------------------Step 3: Run test application for linuxapp environment----------------------------------------------------------[26] Run test application ($RTE_TARGET/app/test)[27] Run testpmd application in interactive mode ($RTE_TARGET/app/testpmd)----------------------------------------------------------Step 4: Other tools----------------------------------------------------------[28] List hugepage info from /proc/meminfo----------------------------------------------------------Step 5: Uninstall and system cleanup----------------------------------------------------------[29] Unbind NICs from IGB UIO or VFIO driver[30] Remove IGB UIO module[31] Remove VFIO module[32] Remove KNI module[33] Remove hugepage mappings[34] Exit ScriptOption:7.先进行配置,我的系统是ubuntu12.04,64位,所以应该输入14,选择x86_64-native-linuxapp-gcc进行编译,如果是32位系统则是x86_x32-native-linuxapp-gcc,或者是i686-native-linuxapp-gcc,因为i386、i686都是32位的,平台选错了会导致后面编译不成功。

dpdk test编译

dpdk test编译

dpdk test编译DPDK(Data Plane Development Kit)是一个开源的数据包处理框架,用于高效处理网络数据包。

下面是编译DPDK test的步骤:1. 首先,下载DPDK的最新版本。

你可以从DPDK的官方网站下载源代码压缩包。

2. 解压缩源代码压缩包到一个合适的目录。

可以使用以下命令进行解压缩:```tar -xf dpdk-x.x.x.tar.gz```这里的x.x.x是DPDK的版本号。

3. 进入解压缩后的源代码目录:```cd dpdk-x.x.x```4. 设置编译环境变量。

可以使用以下命令设置环境变量:```export RTE_SDK=$(pwd)```这里的`$(pwd)`表示当前所在的目录。

5. 定义目标架构。

DPDK支持多种不同的架构,如x86、ARM等。

根据你的需求,执行以下命令定义目标架构:```export RTE_TARGET=xx-xx-xx```这里的`xx-xx-xx`表示目标架构的标识,例如x86_64-native-linuxapp-gcc。

6. 配置编译选项。

执行以下命令进入配置界面:```make config```然后根据提示选择所需的选项。

你可以根据需求启用或禁用不同的功能。

7. 编译DPDK test。

执行以下命令开始编译:```make```编译过程可能需要一些时间,取决于你的系统配置和编译选项。

8. 编译完成后,你可以在`x86_64-native-linuxapp-gcc/app/test`目录中找到生成的可执行文件。

完成上述步骤后,你已成功编译DPDK test。

现在你可以在你的系统上运行测试,并进行网络数据包处理的相关开发工作。

希望以上步骤对你有所帮助。

中国电信DPDK技术白皮书v1.0

中国电信DPDK技术白皮书v1.0
1.1 1.2 问题背景......................................................................................................................... 4 范围................................................................................................................................. 5 技术原理与架构............................................................................................................. 6 软件架构......................................................................................................................... 6 大页技术......................................................................................................................... 8 轮询技术......................................................................................................................... 9 CPU 亲和技术 ................................................................................................................ 9 硬件结构的影响........................................................................................................... 11 OS 版本及其内核的影响............................................................................................. 12 3.2.1 关闭 OS 部分服务.............................................................................................. 12 3.2.2 OS 调整示例....................................................................................................... 13 OVS 性能问题.............................................................................................................. 14 内存管理....................................................................................................................... 14 3.4.1 内存多通道的使用 ............................................................................................. 14 3.4.2 内存拷贝............................................................................................................. 15 3.4.3 内存分配............................................................................................................. 15 3.4.4 NUMA 考虑 ....................................................................................................... 15 CPU 核间无锁通信 ...................................................................................................... 16 设置正确的目标 CPU 类型 ......................................................................................... 17

dpdk+ovs安装和编译(一)

dpdk+ovs安装和编译(一)

dpdk+ovs安装和编译(⼀)绑定前⽹卡驱动[root@localhost ~]# ethtool -i enp5s0driver: hinicversion:firmware-version:expansion-rom-version:bus-info: 0000:05:00.0supports-statistics: nosupports-test: nosupports-eeprom-access: nosupports-register-dump: nosupports-priv-flags: no[root@localhost ~]#安装ovs遇到⼀个问题那就是ovs version和dpdk version不匹配,华为鲲鹏920上安装的dpdk是dpdk-19.11ovs-vsctl add-br br0 -- set bridge br0 datapath_type=netdev[root@localhost ~]# ovs-vsctl add-port br0 dpdk1 -- set Interface dpdk1 type=dpdk options:dpdk-devargs=0000:05:00.0ovs-vsctl: Error detected while setting up 'dpdk1': could not open network device dpdk1 (Address family not supported by protocol). See ovs-vswitchd log for details. ovs-vsctl: The default log directory is "/var/log/openvswitch".[root@localhost ~]# ovs-vsctl showbb6aa323-f96b-4872-98f8-7aa87fc99958Bridge "br0"datapath_type: netdevPort "dpdk1"Interface "dpdk1"type: dpdkoptions: {dpdk-devargs="0000:05:00.0"}error: "could not open network device dpdk1 (Address family not supported by protocol)"Port "br0"Interface "br0"type: internal[root@localhost ~]#查看⽹卡与dpdk绑定状态[root@localhost dpdk-19.11]# ./usertools/dpdk-devbind.py --statusNetwork devices using DPDK-compatible driver============================================0000:05:00.0'Hi1822 Family (2*25GE) 0200' drv=vfio-pci unused=hinic0000:06:00.0'Hi1822 Family (2*25GE) 0200' drv=vfio-pci unused=hinicNetwork devices using kernel driver===================================0000:7d:00.0'HNS GE/10GE/25GE RDMA Network Controller a222'if=enp125s0f0 drv=hns3 unused=hns_roce_hw_v2,vfio-pci *Active*0000:7d:00.1'HNS GE/10GE/25GE Network Controller a221'if=enp125s0f1 drv=hns3 unused=vfio-pci0000:7d:00.2'HNS GE/10GE/25GE RDMA Network Controller a222'if=enp125s0f2 drv=hns3 unused=hns_roce_hw_v2,vfio-pci0000:7d:00.3'HNS GE/10GE/25GE Network Controller a221'if=enp125s0f3 drv=hns3 unused=vfio-pciNo 'Baseband' devices detected==============================No 'Crypto' devices detected============================No 'Eventdev' devices detected==============================No 'Mempool' devices detected=============================No 'Compress' devices detected==============================No 'Misc (rawdev)' devices detected===================================[root@localhost dpdk-19.11]#编译dpdk修改配置⽂件config/common_linuxapp,这⾥我们测试vhost模式,所以需要把下⾯两个配置项,配置为yes。

VMware Workstation Player for Linux 16.0 用户指南说明书

VMware Workstation Player for Linux 16.0 用户指南说明书

使用适用于 Linux 的 VMware Workstation PlayerVMware Workstation Player for Linux 16.0您可以从 VMware 网站下载最新的技术文档:https:///cn/。

VMware, Inc.3401 Hillview Ave. Palo Alto, CA 94304 威睿信息技术(中国)有限公司北京办公室北京市朝阳区新源南路 8 号启皓北京东塔 8 层 801/cn上海办公室上海市淮海中路 333 号瑞安大厦 804-809 室/cn广州办公室广州市天河路 385 号太古汇一座 3502 室/cn版权所有© 2020 VMware, Inc. 保留所有权利。

版权和商标信息使用适用于 Linux 的 VMware Workstation Player目录使用 VMware Workstation Player for Linux91简介和系统要求10Workstation Player 的主机系统要求10主机系统的处理器要求10支持的主机操作系统11主机系统的内存要求11主机系统的显示要求11主机系统的磁盘驱动器要求12主机系统的局域网络连接要求12虚拟机的功能与规范13支持的客户机操作系统13虚拟机处理器支持13虚拟机内存分配13兼容的虚拟机132安装和使用 Workstation Player14在 Linux 主机上安装 Workstation Player 14Linux 命令行安装选项15启动 Workstation Player16使用 Workstation Player 窗口16传输文件和文本17使用拖放功能17使用复制与粘贴功能18在 Workstation Player 中下载虚拟设备19从 Workstation Player 的库中移除虚拟机19卸载 Workstation Player193更改 Workstation Player 首选项设置20配置关闭行为首选项设置20配置软件更新设置21为代理服务器配置连接设置21了解自动软件更新过程21加入或退出客户体验改进计划22配置 Workstation Player 颜色主题设置224在 Workstation Player 中创建虚拟机24了解虚拟机24准备创建虚拟机24选择客户机操作系统25指定虚拟机名称和文件位置26为虚拟机指定磁盘容量27创建虚拟机28使用简易安装来安装客户机操作系统29手动安装客户机操作系统30导入虚拟机31导入开放虚拟化格式虚拟机31导入 VMware vCenter Server Appliance325安装和升级 VMware Tools33安装 VMware Tools33升级 VMware Tools 34配置软件更新首选项35为特定虚拟机配置 VMware Tools 更新36手动安装和升级 VMware Tools36在 Windows 虚拟机中手动安装 VMware Tools36在 Linux 虚拟机中手动安装 VMware Tools37在 NetWare 虚拟机中手动安装 VMware Tools 40在 Solaris 虚拟机中手动安装 VMware Tools40在 FreeBSD 虚拟机中手动安装 VMware Tools41不使用会话管理器时手动启动 VMware 用户进程43卸载 VMware Tools436在 Workstation Player 中启动和停止虚拟机45在 Workstation Player 中启动虚拟机45在 Workstation Player 中启动加密的虚拟机46在 Workstation Player 中下载虚拟设备46在 Workstation Player 中关闭虚拟机46从 Workstation Player 的库中移除虚拟机47使用 Ctrl+Alt+Delete 关闭客户机47在 Workstation Player 中挂起和恢复虚拟机47在 Workstation Player 中复位虚拟机48在 Windows 虚拟机中启用自动登录48设置 Workstation Player 的虚拟机关闭行为首选项497更改虚拟机显示50为虚拟机配置显示设置50在 Workstation Player 中使用全屏模式51在客户机中报告电池信息52为一个虚拟机使用多个监视器52多监视器的限制538在虚拟机中使用可移动设备和打印机54在虚拟机中使用可移动设备54将 USB 设备连接到虚拟机55禁用 USB 设备的自动连接55将 USB HID 连接到虚拟机55安装 PDA 驱动程序并与虚拟机同步56排除 USB 设备控制共享问题56允许虚拟机打印到主机打印机57将虚拟打印机添加到虚拟机57安装 VMware 虚拟打印机58卸载 VMware 虚拟打印机59在虚拟机中使用智能卡60在虚拟机中使用智能卡61禁用智能卡共享62在 Linux 主机上切换到虚拟智能卡读卡器629为虚拟机设置共享文件夹63使用共享文件夹63支持共享文件夹的客户机操作系统64使用权限限制对 Linux 客户机中共享文件的访问权限64为虚拟机启用共享文件夹65在 Windows 客户机中查看共享文件夹66在 Linux 客户机中装载共享文件夹66更改共享文件夹属性67更改虚拟机能够共享的文件夹68为虚拟机禁用文件夹共享68将虚拟磁盘映射到主机系统69将虚拟磁盘映射或装载到主机系统上的驱动器69从主机系统断开虚拟磁盘6910配置和管理虚拟机71更改虚拟机名称71更改虚拟机的客户机操作系统72更改虚拟机的工作目录72更改虚拟机的虚拟机目录73更改虚拟机的内存分配73配置视频和声音74设置屏幕色深74使用 3D 图形加速75配置声音76移动虚拟机77将虚拟机移到新位置或新主机77配置虚拟机兼容性78使用虚拟机 UUID79将虚拟机配置为 VNC 服务器79为 VNC 客户端指定某种语言的键盘映射80使用 VNC 客户端连接到虚拟机82查看虚拟机的 VNC 连接82删除虚拟机83查看虚拟机的消息日志83在虚拟机中安装新软件83在程序无法运行时禁用加速8411配置和管理设备85配置 DVD、CD-ROM 和软盘驱动器85将 DVD 或 CD-ROM 驱动器添加到虚拟机85将软盘驱动器添加到虚拟机86为 DVD 或 CD-ROM 驱动器配置旧版仿真模式87配置 USB 控制器87将 USB 控制器添加到虚拟机88启用同步 USB 设备支持88配置和维护虚拟硬盘89配置虚拟硬盘90压缩虚拟硬盘92扩展虚拟硬盘92整理虚拟硬盘碎片93从虚拟机中移除虚拟硬盘94使用锁定文件防止虚拟硬盘上的一致性问题94将虚拟硬盘移动到新位置94配置虚拟端口95将虚拟并行端口添加到虚拟机95在 Linux 2.6.x 内核主机上配置虚拟并行端口96在 Linux 主机上为并行端口设备配置权限97对并行端口的 ECR 错误进行故障排除97将虚拟串行端口添加到虚拟机98更改串行连接的输入速度99配置通用 SCSI 设备99将通用 SCSI 设备添加到虚拟机100在 Linux 主机上避免 SCSI 设备的并行访问问题100对检测通用 SCSI 设备时遇到的问题进行故障排除101配置十六路虚拟对称多处理102配置十六路虚拟对称多处理102使用具有十六个以上虚拟处理器的虚拟机102配置键盘功能103在按键组合中使用 Ctrl+Alt103配置远程 X 服务器的键盘映射104更改特定按键的映射方式105配置键盘符号的映射方式105V-Scan 代码表107修改虚拟机的硬件设置11012配置网络连接111了解虚拟网络连接组件111了解常见网络连接配置112配置桥接模式网络连接113在桥接模式网络连接环境中分配 IP 地址114为现有虚拟机配置桥接模式网络连接114配置网络地址转换114配置仅主机模式网络连接115为现有虚拟机配置仅主机模式网络连接116更改网络连接配置116查找虚拟机的网络类型116将虚拟网络适配器添加到虚拟机117修改虚拟机的现有虚拟网络适配器117启用巨型帧118在 Linux 主机上启用巨型帧11813配置虚拟机选项设置119为虚拟机配置常规选项设置119更改虚拟机名称120更改客户机操作系统120更改虚拟机工作目录120为虚拟机配置电源选项120为虚拟机配置 VMware Tools 选项121为虚拟机配置自动登录12114配置虚拟机硬件设置123将硬件添加到虚拟机124从虚拟机中移除硬件125调整虚拟机内存125配置虚拟机处理器设置126配置和维护虚拟硬盘126对虚拟硬盘进行碎片整理127扩展虚拟硬盘127压缩虚拟硬盘128将虚拟磁盘映射到主机系统128更改虚拟硬盘节点和模式设置129配置 CD-ROM 和 DVD 驱动器设置129配置 CD-ROM 和 DVD 驱动器状态和连接设置130更改虚拟设备节点和旧版模拟设置130配置软盘驱动器设置130配置虚拟网络适配器设置131配置虚拟网络适配器设备状态设置131配置桥接模式网络连接132配置网络地址转换132配置仅主机模式网络连接133配置 LAN 区段133配置虚拟网络适配器高级设置133配置 USB 控制器设置134配置声卡设置135配置并行端口设置135配置串行端口设置135配置通用 SCSI 设备设置136配置打印机设置136配置显示设置137在物理磁盘或未使用的分区上安装客户机操作系统13715使用 VMware Workstation Player REST API139使用 VMware Workstation Player REST API139使用 VMware Workstation Player for Linux《使用 VMware Workstation Player for Linux》介绍了如何使用 VMware Workstation Player™创建、配置和管理 Linux 主机上的虚拟机。

dpdk收包流程

dpdk收包流程

dpdk收包流程DPDK收包流程简介本文将详细介绍DPDK的收包流程,包括收包的准备工作、收包的处理流程以及收包的后续操作。

收包前的准备工作在开始进行收包处理之前,需要进行一些准备工作。

•网卡绑定到DPDK驱动程序–使用dpdk-devbind工具,将网卡绑定到DPDK的驱动程序,以便DPDK能够访问网卡并接收数据包。

•创建和初始化DPDK环境–调用rte_eal_init()函数来创建和初始化DPDK环境,包括内存的分配和设备的初始化等。

•设置接收队列和缓冲区–调用rte_eth_rx_queue_setup()函数来设置接收队列和缓冲区,以便DPDK能够接收数据包,并将其存储在内存中的缓冲区中。

收包的处理流程一旦准备工作完成,DPDK就可以开始接收和处理数据包了。

1.数据包接收–当网卡收到数据包时,硬件会触发中断,通知DPDK进行数据包接收。

–DPDK会检查接收队列上的缓冲区是否可用,并将数据包存储到空闲的缓冲区中。

2.数据包预处理–在进行后续处理之前,DPDK可以对收到的数据包进行一些预处理操作,例如校验和校验、vlan标记和分片重组等。

3.数据包分发–DPDK支持多个逻辑核心进行并行处理,因此需要将接收到的数据包分发给不同的处理核心。

–通过一种策略,例如RSS(接收侧扩展散列)或轮询,将数据包分发给不同的核心。

4.数据包处理–每个处理核心会从接收队列中取出一个或多个数据包,进行业务逻辑处理。

–处理逻辑可能包括解析协议头、数据包过滤、网络功能处理等。

收包的后续操作一旦数据包处理完成,可以进行一些后续操作。

•数据包转发–如果DPDK作为一个网络应用,可以将处理完的数据包转发给其他网络设备或应用程序。

•数据包发送–如果需要,DPDK可以将处理完的数据包发送出去,通过调用rte_eth_tx_burst()函数将数据包发送到指定的网卡上。

•资源释放–处理完的数据包和相关的资源需要进行释放,以避免资源泄漏。

DPDK安装步骤详细说明

DPDK安装步骤详细说明

前言DPDK是专为快速收发包所开发的一系列的库文件和驱动代码。

可以在Intel的芯片上运行。

可以用来●在极短的时间里面完成收发包(一般低于80个周期)●可以开发快速的抓包算法。

●可以运行第三方的快速路径栈而DPDK最大的优点就是改进小封包吞吐量与作业负荷效能,传统的网路架构都是针对大封包吞吐量进行最佳化,而Intel® DPDK可以解决小封包所带来效能不佳的问题。

除了应用在企业终端外, Intel DPDK 也可以在软体定义网路(SDN) 与网路功能虚拟化(NFV) 中扮演着重要的角色。

本文主要是对官方提供的《intel-dpdk-getting-started-guide Revision-002》进行总结,提取其中的关键知识点。

同时对一些知识点进行了延伸,方便新手对DPDK的一些相关概念有个基本的认识,对整个DPDK的安装过程有个整体的认识第一章一些基本概念刚开始接触DPDK的时候,会遇到很多基本的概念,通过后面的测试实践发现,很多时候都是由于基本概念不明导致错误不能被检查出来,所有本文总结了一些相关的概念,同时对概念下面的一些子概念也进行了一定的延伸。

1.1L inux环境下的UIO( Userspace I/O )UIO指的是运行在用户空间的I/O技术,是实现用户空间下驱动程序的支撑机制。

Linux系统中一般的驱动设备都是运行在内核空间,而在用户空间用应用程序调用即可,而UIO则是将驱动的很少一部分运行在内核空间,而在用户空间实现驱动的绝大多数功能。

使用UIO可以避免设备的驱动程序需要随着内核的更新而更新的问题。

由于DPDK是应用层平台,所以与此紧密相连的网卡驱动程序(主要是intel自身的千兆igb与万兆ixgbe驱动程序)都通过uio机制运行在用户态下。

Intel® DPDK 的igb_uio 内核模块依赖于内核的UIO。

需要以模块方式编译可以通过如下命令进行编译sudo /sbin/modprobe uio1.2大内存页(Hugepages)机制1.2.1如何配置大内存页大内存页指的是为包处理的缓冲区缓冲区分配更大的大内存池,利用大内存页的主要好处当然是通过利用大内存页提高内存使用效率。

DPDK2.1linux上开发入门手册

DPDK2.1linux上开发入门手册

DPDK2.1linux上开发⼊门⼿册1引⾔ 本⽂档主要包含INTEL DPDK安装和配置说明。

⽬的是让⽤户快速的开发和运⾏程序。

⽂档描述了如何在不深⼊细节的情况下在linux应⽤开发环境上编译和运⾏⼀个DPDK应⽤程序。

1.1⽂档总览 以下是DPDK⽂档列表,建议按照⽂档顺序阅读:Release Note:提供版本特有信息,包括⽀持的型号,限制,修正的问题,⼀直的问题等等。

也提供⼀些在常见问题解答中被频繁问道的问题的⼤案。

⼊门指导(Getting Started Guide(本⽂档)):描述怎么安装和配置DPDK,⽬的是让⽤户快速开发和运⾏软件。

开发⼿册(Programmer's Guide):描述:软件架构和如何在linux环境下运⾏⼀个DPDK范例程序DPDK的内容,开发系统(包括如何在DPDK根⽬录下使⽤的编译Makefile的指令来编译开发库和运⽤程序)和移植⼀个应⽤程序参考软件优化和需要在新的开发环境考虑的问题。

也提供了关键词汇表: API⼿册:提供了DPDK上的函数,数据结构和其它编程结构的详细信息。

范例使⽤⼿册(Sample Application User Guide):描述了⼀系列的范例程序,每个章节都描述了⼀个有特殊功能的⽰例,提供了编译,运⾏和使⽤⽰例的操作指南。

注意:以上⽂档都可以从DPDK源码包的同⼀个位置上分别下载。

2系统必备条件本章讲的是编译DPDK源码包必须具有的环境。

注意:如果DPDK要⽤到intel的89XX系列的⽹卡平台上,请先翻阅89xx⽹卡系列的⼊门⼿册。

2.1X86上BIOS先决条件 对于主要的平台,没有什么特别的BIOS设置才能⽤DPDK的基本功能。

然⽽总有例外的,对于HPET⾼精度时钟,能源管理功能,在40g⽹卡上⾼性能的⼩包收发,BIOS设置需要改⼀下。

请看第5章(其它功能的开启)来获取需要做哪些更改的信息。

2.2编译DPDK注意:测试是在Fedora18上,编译安装指令在其它系统上可能不⼀样。

dpdk编程

dpdk编程

dpdk编程一、什么是dpdk1.1 dpdk的概述DPDK(Data Plane Development Kit)是一个软件开发工具集,用于加速数据平面应用程序的开发。

它是由英特尔(Intel)开发的,旨在提供高性能、低延迟的数据包处理能力。

DPDK可以通过绕过操作系统内核,直接访问网络硬件设备,从而更高效地执行网络数据包的处理任务。

1.2 dpdk的特点和优势•高性能:使用DPDK进行数据包处理可以显著提高性能,通过直接访问硬件设备和使用高度优化的算法,减少了数据包处理的延迟。

•低延迟:DPDK可以绕过操作系统内核,减少了上下文切换和系统调用带来的延迟,使得数据包可以以更低的延迟进行处理。

•可扩展性:DPDK使用多核心技术,可以将数据包处理任务分发到多个处理核心上,实现并行处理,提高了系统的可扩展性。

•硬件无关性:DPDK支持多种网络设备,包括以太网、虚拟网卡等,使得开发人员可以在不同的硬件平台上使用统一的API进行开发。

1.3 dpdk的应用领域和案例•云计算:DPDK可以用于虚拟化环境中,加速虚拟机之间的网络通信,提高云计算平台的性能和可扩展性。

•网络安全:DPDK可以用于实时监测和分析网络流量,并进行高效的数据包过滤和安全检测,提供更高级的网络安全保护。

•5G通信:DPDK可以用于5G通信中,加速数据平面的处理能力,提供更高的带宽和低延迟,满足5G通信对于网络性能的要求。

二、dpdk的基本原理2.1 数据平面和控制平面在传统的网络设备中,数据平面和控制平面通常由操作系统内核来处理。

数据平面负责数据包的转发和处理,而控制平面负责路由表的维护和控制策略的制定。

而使用DPDK编程时,可以将数据平面的处理任务由操作系统内核转移到用户空间,从而提高数据包处理的效率和性能。

2.2 数据包处理模型DPDK的基本处理单元是数据包,其处理过程可以分为以下几个阶段: 1. 接收阶段:网卡接收到数据包,并将其从硬件设备中读取到内存中。

dpdk的基本概念 -回复

dpdk的基本概念 -回复

dpdk的基本概念-回复DPDK(Data Plane Development Kit)是一个开源的软件开发工具集,用于提供高性能的数据平面处理。

它的目标是通过优化数据平面处理,提供低延迟和高吞吐量的网络解决方案。

本文将逐步介绍DPDK的基本概念及其在网络应用中的应用场景。

1. DPDK的概述DPDK是由Intel创建的一个开源项目,旨在提供一套高效的数据平面开发工具。

它利用了现代处理器和硬件加速技术,实现了绕过操作系统内核的数据平面处理,从而大幅度提高了网络应用的性能。

DPDK支持在多核处理器上进行并行处理,并为网络应用提供了一系列优化的库和驱动程序。

2. DPDK的核心组件DPDK的核心组件包括:- 模块化内存管理:DPDK提供了一种高效的模块化内存管理机制,用于实现零拷贝数据传输。

它通过预分配内存池,并使用指针和描述符来直接访问内存,避免了数据复制和操作系统调用的开销。

- 多线程支持:DPDK充分利用了多核处理器的并行性能。

它提供一套多线程编程模型,支持线程的创建和调度,使得网络数据包的处理可以在多个核上同时进行,提高了系统的吞吐量。

- 高性能网络驱动程序:DPDK提供了一系列高性能的网络驱动程序,支持多种网络接口,如以太网、虚拟网卡等。

这些驱动程序利用硬件加速技术,提供了零拷贝和零中断的数据传输,从而实现了高性能的数据平面处理。

- 优化的协议栈:DPDK还提供了一套优化的协议栈,用于实现网络协议的处理和数据包转发。

这个协议栈包括了各种协议的实现,如IPv4、IPv6、TCP、UDP等,能够提供低延迟和高吞吐量的网络传输。

3. DPDK的应用场景DPDK可以用于各种网络应用场景,如网络流量监控、虚拟化网络、云计算等。

它的高性能和低延迟特性使得它在这些场景中具有很大的优势。

- 网络流量监控:DPDK可以利用硬件加速技术,从网络中捕获和分析数据包,实现高效的网络流量监控。

它可以同时处理大量的网络数据包,提供实时的数据包过滤、统计和分析功能。

ubuntu14.04下安装dpdk及运行

ubuntu14.04下安装dpdk及运行

ubuntu14.04下安装DPDK一.硬件环境:cpu: intel i7-4790K内存:金士顿32G DDR3硬盘:华硕z97-K硬盘:1TBISO:需要支持HPET(Advanced->PCH-IO Configuration -> High Precision Timer 选择Enable)PCIE: 1 x PCIe 3.0/2.0 x16 扩展卡插槽(x16 模式, 灰色)开启HPET:# grep hpet /proc/timer_list如果没有显示,则需要在BIOS中开启HPET开启方式:进入BIOS进入Advanced -> PCH-IO Configuration -> High Precision Timer把High Precision Timer从Disabled 改为Enabled二. 软件环境从ubuntu官网下载ubuntu14.04 64位系统下载地址:/download/desktopDPDK2.0要求:kernel-version >=2.6.33 :查看命令uname –rglibc>=2.7: 查看命令ldd --version下载安装完成后建立root用户:1.在终端下输入:sudo passwd root输入root密码2.更改配置文件,使能root登陆sudo gedit /usr/share/lightdm/lightdm.conf.d/50-ubuntu.conf增加以下两条命令:greeter-show-manual-login=trueallow-guest=false3.重启,以root用户登陆三.DPDK安装3.1 DPDK下载DPDK各种版本下载地址: /browse/dpdk/refs/ 本次使用的是DPDK 2.0版本,直接从官网下载:打开ubuntu终端,安装git:apt-get install git安装dpdk:git clone git:///dpdk3.2 DPDK编译安装3.2.1编译cd /root/dpdkmake config T=x86_64-native-linuxapp-gcc && makemake install T=x86_64-native-linuxapp-gcc3.2.2加载内核模块打开~/.bashrc,写入下面命令modprobe uio_pci_generic3.2.3设置大内存页,隔离cpu设备的配置是32G内存,分出16G的大内存页给DPDK使用,并将1,2,3,4,5,6,7这7个cpu隔离出来,设置1G大内存页和隔离cpu需要在内核启动参数中设置,具体如下:查看cpu是否支持1G大内存页:cat /proc/cpuinfo | grep pdpe1gb如果有显示,则支持1G大内存页默认支持2M内存页cat /proc/cpuinfo |grep pse如果有显示,则支持2M内存页vim /etc/default/grub找到GRUB_CMDLINE_LINUX=””,在双引号中添加default_hugepagesz=1G hugepagesz=1G hugepages=16 isolcpus=1,2,3,4,5,6,7执行update-grub命令打开~/.bashrc,写入以下两条命令:mkdir –p /mnt/hugemount –t hugetlbfs nodev /mnt/huge重启系统:reboot3.2.4绑定网卡运行/root/dpdk/tools下的dpdk_nic_bind.py脚本绑定网卡./tools/dpdk_nic_bind.py --bind=uio_pci_generic [device0] 首先通过脚本看看本机有哪些可用的网卡,包括网卡当前的状态./tools/ dpdk_nic_bind.py –status输出如下Network devices using IGB_UIO driver====================================<none>Network devices using kernel driver===================================0000:02:00.0 'I350 Gigabit Network Connection' if=eth0 drv=igb unused=igb_uio *Active*Other network devices=====================0000:83:00.0 '82599EB 10-Gigabit SFI/SFP+ Network Connection' unused=ixgbe,igb_uio0000:83:00.1 '82599EB 10-Gigabit SFI/SFP+ Network Connection' unused=ixgbe,igb_uio从上面的输出可以可以看到有两个intel 10G网口并没有绑定到任何驱动。

实验二 利用DPDK构造并发送数据包

实验二 利用DPDK构造并发送数据包

实验二利用DPDK构造并发送数据包一、实验目的1.学会编写和测试DPDK发包程序2.理解DPDK实现高性能收发包的原理二、实验内容1.编写一个DPDK程序,实现如下功能:直接构造一个数据包(内容任意),要求数据包的协议头符合UDP/IP/Ethernet协议规范,并将其发送出去。

该程序基于skeleton程序修改得到,附录中给出一个供参考的编程框架。

2.使用tcpdump命令,抓取数据包,观察各协议头的字段值,确认实际输出与程序意图是否一致。

过程举例:1.//在命令行窗口运行如下命令2.//抓取经过指定网卡含有特定端口号的数据包3.sudo tcpdump -vv -A -e -i <网卡名称> port <端口号>4.//然后在另一窗口运行DPDK程序5.6.//注意:tcpdump只能在内核驱动网卡上抓取数据包7.//tcpdump的更多用法可参阅相关资料三、回答问题官方文档:DPDK documentation, DPDK API注意:不同版本DPDK对应的文档内容也不完全一样,应对应查看1.UDP协议头的cksum是必须的吗?不是的话应当如何设置?2.DPDK为IP协议头的cksum计算提供了专用函数,请在相关文档中找到它,并应用在程序中,调用该函数的注意事项是什么?3.DPDK实现高性能收发包的原理是什么?四、思考题参照本实验,一个接收数据包并处理其中数据的DPDK程序应该如何实现?五、进展报告本实验的完成情况以及对以上3个问题的回答作为第二阶段的进展报告,于 11 月 2日23:59之前上传到http://202.38.75.243:5050/。

11月5日课堂讨论。

进展报告中需注明小组成员(组长排在第一个),以及每位成员对该报告的贡献比例。

上课前各小组做好PPT,以备报告。

文件命名及格式:第二阶段_组长姓名.pdf。

实验过程中遇到任何问题,请及时发邮件给助教(linfei@),并抄送一份给主讲老师。

dpdk常用命令

dpdk常用命令

dpdk常用命令DPDK是一种高效的网络数据包处理框架,可以实现高性能的数据包收发和处理。

在使用DPDK的过程中,常常需要使用一些命令进行配置和管理。

本文将介绍DPDK常用命令,以便读者能够更好地掌握DPDK的使用。

1. dpdk_nic_bind.pydpdk_nic_bind.py是DPDK提供的一个Python脚本工具,用于绑定和解绑网络接口卡和DPDK的驱动程序。

通过该工具可以实现以下功能:- 列出系统的所有网络接口卡及其状态- 绑定网络接口卡到DPDK的驱动程序- 解绑网络接口卡使用方式:列出系统的所有网络接口卡及其状态:绑定网络接口卡到DPDK的驱动程序:sudo ./dpdk_nic_bind.py --bind=驱动程序名网络接口名解绑网络接口卡:2. dpdk-setup.shdpdk-setup.sh是DPDK提供的一种交互式的配置工具,可用于配置DPDK的环境变量、huge页面等。

通过该工具可以设置以上参数:- 设置DPDK环境变量- 设置使用的DPDK驱动程序- 分配huge页面执行脚本:选择“Enter DPDK Environment Variables”设置DPDK环境变量:export RTE_SDK=/path/to/dpdkexport RTE_TARGET=x86_64-native-linuxapp-gcci40e,mlx5_kvme,mlx4_enp1s0f1选择“Allocate Hugepages”设置huge页面:Set the number of 2M pages: 1024Total memory: 2048 MBTotal hugepage size: 2048 MBHugepage size: 2048 MBSuccess: 10243. rtecli- 显示DPDK应用程序的状态- 重启DPDK应用程序sudo ./app/rtecli -c APPNAMEshow stats重启DPDK应用程序:dpdk-pdump是DPDK提供的一个数据包抓取工具,可以实现抓取数据包并将其保存到文件中。

dpdk收包流程

dpdk收包流程

DPDK收包流程详解概述DPDK(Data Plane Development Kit)是一个高性能数据包处理框架,用于快速开发数据包处理应用程序。

它提供了一组优化的API和库,可在通用处理器上实现数据平面功能,如报文接收、报文处理和报文发送。

本文将详细描述DPDK的收包流程。

收包流程步骤DPDK的收包流程主要包括以下步骤:1.初始化DPDK环境2.配置物理设备3.分配内存池4.创建和配置设备队列5.启动设备6.接收数据包7.处理数据包8.发送数据包9.释放资源下面将逐一详细介绍每个步骤。

1. 初始化DPDK环境DPDK程序的第一步是初始化DPDK环境。

初始化过程包括解析命令行参数、初始化DPDK库、配置内存和线程等。

DPDK提供了一个初始化函数rte_eal_init(),用于初始化DPDK环境。

int rte_eal_init(int argc, char **argv);2. 配置物理设备在DPDK中,需要配置物理设备以便进行数据包收发。

物理设备的配置包括设置设备的属性,如网卡的PCI地址、队列数目、队列深度等。

DPDK提供了一组API用于配置物理设备,如rte_eth_dev_configure()和rte_eth_rx_queue_setup()。

int rte_eth_dev_configure(uint16_t port_id, uint16_t nb_rx_queues, uint16_t nb _tx_queues, const struct rte_eth_conf *eth_conf);int rte_eth_rx_queue_setup(uint16_t port_id, uint16_t rx_queue_id, uint16_t nb_rx_desc, unsigned int socket_id, const struct rte_eth_rxconf *rx_conf, struct rte_mempool *mb_pool);3. 分配内存池DPDK使用内存池(Memory Pool)来存储接收和发送数据包的缓冲区。

dpdk三层转发详解

dpdk三层转发详解

dpdk三层转发详解(原创版)目录1.DPDK 概述2.三层转发的原理3.DPDK 的三层转发实现4.DPDK 三层转发的优化正文【DPDK 概述】DPDK(Data Plane Development Kit)是一个开源的软件开发工具包,主要用于加速数据平面的处理。

它提供了一组丰富的库和驱动程序,以方便开发者快速实现高速网络接口卡(NIC)和虚拟交换机(vSwitch)等数据平面设备。

DPDK 广泛应用于云计算、虚拟化和软件定义网络(SDN)等领域。

【三层转发的原理】三层转发,也称为网络层转发,主要负责处理 IP 协议的数据包。

在网络通信中,数据包需要通过三层转发实现在不同网络之间的传输。

三层转发的原理主要包括以下几个步骤:1.接口接收数据包:网络接口卡(NIC)接收到来自物理层的数据包,并将其发送给 DPDK 内核。

2.数据包解析:DPDK 内核解析数据包的头部信息,提取目的 MAC 地址和目的 IP 地址。

3.路由查找:DPDK 内核根据目的 IP 地址进行路由查找,以确定数据包的下一跳(下一跳 IP 地址)。

4.数据包转发:DPDK 内核将数据包转发到下一跳,可以是同一网络接口卡,也可以是其他网络接口卡或远程网络设备。

【DPDK 的三层转发实现】DPDK 的三层转发实现主要依赖于其内部的数据结构和算法。

具体来说,DPDK 的三层转发实现包括以下几个方面:1.虚拟交换机:DPDK 提供了虚拟交换机(vSwitch)功能,可以实现多虚拟机之间的网络互通。

虚拟交换机内部使用虚拟端口(vPort)和虚拟链路(vLink)表示虚拟机之间的连接关系。

2.端口和链路:DPDK 将物理网卡抽象为逻辑端口(port),将物理链路抽象为逻辑链路(link)。

逻辑端口和逻辑链路可以方便地进行配置、绑定和解绑等操作。

3.报文处理:DPDK 提供了报文处理引擎(Packet Processing Engine, PPE),用于处理网络接口卡接收到的数据包。

Linux环境下DPDK中文入门文档

Linux环境下DPDK中文入门文档

Linux环境下DPDK中文入门文档Release 17.02.0 目录Linux环境下DPDK入门 (1)1 引言 (2)2 资料集 (2)3 系统需求 (2)3.1 x86平台的先决条件BIOS设置 (2)3.2 编译DPDK. 33.3 运行DPDK程序 (3)4 编译DPDK源码 (5)4.1 安装DPDK和浏览源码 (5)4.2 安装DPDK目标(target)开发环境 (6)4.3 浏览安装好的DPDK环境target. 64.4 加载DPDK用户态IO模块 (7)4.5 加载VFIO模块 (7)4.6 从内核模块绑定和解绑网卡 (7)5 编译和运行例子程序 (8)5.1 编译例子程序 (8)5.2 运行例子程序 (9)5.2.1 程序使用的逻辑核 (9)5.2.2 程序使用的大页内存 (10)5.3 其它例子程序 (10)5.4 其它的测试程序 (10)6 开启其它功能 (10)6.1 高精度定时器(HPET)功能 (10)6.1.1 BIOS支持 (10)6.1.2 linux内核支持 (11)6.2 非root用户运行DPDK程序 (11)6.3 电源管理和省电功能 (11)6.4 使用DPDK的CPU亲和性减少上下文切换的开销 (12)6.5 加载DPDK KNI内核模块 (12)6.6 使用linux IOMMU透传来在INTEL VT-d虚拟化环境下运行DPDK. 12 6.7 40G网口高性能小包处理 (12)6.7.1 使用16个字节的RX描述符 (12)6.7.2 高性能和报文时延间的均衡 (12)7 快速安装启动脚本 (12)7.1 脚本结构 (13)7.2 用例 (13)7.3 应用程序 (15)8 怎么在intel平台上获得网卡的最好性能 (17)8.1 硬件和内存需求 (17)8.1.1 网卡需求 (18)8.1.2 BIOS设置 (18)8.1.3 Linux内核启动参数 (18)8.2 运行DPDK前的配置 (18)8.3 获取intel网卡的最好性能例子 (19)1 引言文档是安装配置DPDK操作说明,旨在帮助客户快速上手和运行程序。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

DPDK安装及示例程序使用指南(适用于虚拟机)--torronto 2016.1.27 关于dpdk的介绍不用多说,主要就是它是intel开发的一个网络数据包查找转发的套件,用以分析网络数据的,所以只支持intel的网卡以及极少数除intel之外的网卡,具体支持的型号,官网有说明。

因此,大多数时候,我们都是用虚拟机来仿真。

1.在虚拟机中的ubuntu系统上手动设置2个网卡(一共3个),就使用默认的桥接模式,然后修改处理器个数为2个处理器,每个处理器2核心。

内存分配,1GB以上,2GB更好。

2.去官网下载dpdk软件包,http://www.dpdk.eu/download3.将软件包解压在主目录下,根据个人喜好,因为后面编译和使用示例每次都要访问的。

4.从终端进入5.tools文件夹中有一个setup.sh方便新手完成dpdk的设置初始化操作:(当然,配置编译之前先进入特权模式)6.我们可以看到setup.sh里的一些选项如下:------------------------------------------------------------------------------RTE_SDK exported as /home/torronto/dpdk-2.2.0----------------------------------------------------------------------------------------------------------------------------------------Step 1: Select the DPDK environment to build----------------------------------------------------------[1] arm64-armv8a-linuxapp-gcc[2] arm64-thunderx-linuxapp-gcc[3] arm64-xgene1-linuxapp-gcc[4] arm-armv7a-linuxapp-gcc[5] i686-native-linuxapp-gcc[6] i686-native-linuxapp-icc[7] ppc_64-power8-linuxapp-gcc[8] tile-tilegx-linuxapp-gcc[9] x86_64-ivshmem-linuxapp-gcc[10] x86_64-ivshmem-linuxapp-icc[11] x86_64-native-bsdapp-clang[12] x86_64-native-bsdapp-gcc[13] x86_64-native-linuxapp-clang[14] x86_64-native-linuxapp-gcc[15] x86_64-native-linuxapp-icc[16] x86_x32-native-linuxapp-gcc----------------------------------------------------------Step 2: Setup linuxapp environment----------------------------------------------------------[17] Insert IGB UIO module[18] Insert VFIO module[19] Insert KNI module[20] Setup hugepage mappings for non-NUMA systems[21] Setup hugepage mappings for NUMA systems[22] Display current Ethernet device settings[23] Bind Ethernet device to IGB UIO module[24] Bind Ethernet device to VFIO module[25] Setup VFIO permissions----------------------------------------------------------Step 3: Run test application for linuxapp environment----------------------------------------------------------[26] Run test application ($RTE_TARGET/app/test)[27] Run testpmd application in interactive mode ($RTE_TARGET/app/testpmd)----------------------------------------------------------Step 4: Other tools----------------------------------------------------------[28] List hugepage info from /proc/meminfo----------------------------------------------------------Step 5: Uninstall and system cleanup----------------------------------------------------------[29] Unbind NICs from IGB UIO or VFIO driver[30] Remove IGB UIO module[31] Remove VFIO module[32] Remove KNI module[33] Remove hugepage mappings[34] Exit ScriptOption:7.先进行配置,我的系统是ubuntu12.04,64位,所以应该输入14,选择x86_64-native-linuxapp-gcc进行编译,如果是32位系统则是x86_x32-native-linuxapp-gcc,或者是i686-native-linuxapp-gcc,因为i386、i686都是32位的,平台选错了会导致后面编译不成功。

编译界面如下,有点长。

如果编译有错,往往是软件包依赖关系不满足,安装相应的软件包,对于ubuntu15.10出的错可能和内核有关,所以建议使用的linux3.x内核的。

8.编译完成后,载入IGB组件9.设置页大小先设置位128,即128*2MB的页大小10.选择[28] List hugepage info from /proc/meminfo可以查看页大小,以及多少页是空闲的11.查看当前网卡状态通过上图,我们看出有三块网卡,都是intel e1000型号的,下面两块网卡是我们后来手动添加的,然而都是active的状态,要将他们作为dpdk的网卡,就必须要先关掉另开一个终端:再次查看,网卡状态,可以进行网卡绑定了:12.绑定网卡选择[23] Bind Ethernet device to IGB UIO module输入网卡前面的数字序号,即可绑定该网卡,这里我们有两个需要绑定,eth1和eth2,它们的序号分别是0000:02:06.0和0000:02:07.0绑定完再次查看网卡状态,我们可以看见两个网卡都已经是用于dpdk了:13.到这一步dpdk的配置都已经结束了,下面可以运行一下dpdk自带的示例程序,比如说testpmd:选择[27] Run testpmd application in interactive mode ($RTE_TARGET/app/testpmd)然后会出现testpmd>的显示如下,即显示了start到stop之间发送接受的包数量Port 0 Link Up - speed 1000 Mbps - full-duplexPort 1 Link Up - speed 1000 Mbps - full-duplexDonetestpmd> startio packet forwarding - CRC stripping disabled - packets/burst=32nb forwarding cores=1 - nb forwarding ports=2RX queues=1 - RX desc=128 - RX free threshold=0RX threshold registers: pthresh=0 hthresh=0 wthresh=0TX queues=1 - TX desc=512 - TX free threshold=0TX threshold registers: pthresh=0 hthresh=0 wthresh=0TX RS bit threshold=0 - TXQ flags=0x0testpmd>testpmd> stopTelling cores to stop...Waiting for lcores to finish...---------------------- Forward statistics for port 0 ----------------------RX-packets: 149536 RX-dropped: 0 RX-total: 149536 TX-packets: 149536 TX-dropped: 0 TX-total: 149536 -------------------------------------------------------------------------------------------------- Forward statistics for port 1 ----------------------RX-packets: 149536 RX-dropped: 0 RX-total: 149536 TX-packets: 149536 TX-dropped: 0 TX-total: 149536 ----------------------------------------------------------------------------+++++++++++++++ Accumulated forward statistics for all ports+++++++++++++++RX-packets: 299072 RX-dropped: 0 RX-total: 299072TX-packets: 299072 TX-dropped: 0 TX-total: 299072++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ++++++Done.testpmd>输入quit即可退出。

相关文档
最新文档