使用纯净环境搭建dpdk测试环境:

使用vmware虚拟机安装dpdk环境进行测试。

虚拟机用16.04ubuntu

dpdk用dpdk-19.08.2.tar(官网下载)

1:安装dpdk环境前准备。

1:新的虚拟机环境,换源,更新,安装gcc,g++,确保python安装
2:增加网络适配器,增加处理器,可能要增大内存,设置多网卡。

这里我

第一个网络适配器桥接模式,作为dpdk多网卡测试环境。

第二个网络适配器net模式,作为连接xshell方便操作命令。

3: 重启查看当下网络状况,增加配置使多网卡ip都能生效(参考第四步,在/etc/network/interfaces中增加)。
4: 在虚拟机关机状态下,修改虚拟机对应的配置文件,使其支持多网卡。

如果发现配置文件中没有对应字段,直接增加就可以。 一般是把对应字段由e1000 改为vmxnet3

ethernet0.virtualDev = "vmxnet3"
ethernet0.wakeOnPcktRcv = "TRUE"

重启后,查看,这里可能发现设置后,网卡名称发生变化,按照第二步,重新修改配置生效就好:

hlp@ubuntu:~$ ifconfig
ens38     Link encap:Ethernet  HWaddr 00:0c:29:1d:08:5f  
          inet addr:192.168.11.158  Bcast:192.168.11.255  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fe1d:85f/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:5752 errors:35 dropped:35 overruns:0 frame:0
          TX packets:2164 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:8571580 (8.5 MB)  TX bytes:125904 (125.9 KB)
          Interrupt:16 Base address:0x2000 

ens160    Link encap:Ethernet  HWaddr 00:0c:29:1d:08:55  
          inet addr:192.168.50.62  Bcast:192.168.50.255  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fe1d:855/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:657 errors:0 dropped:0 overruns:0 frame:0
          TX packets:13 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:54652 (54.6 KB)  TX bytes:1554 (1.5 KB)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:160 errors:0 dropped:0 overruns:0 frame:0
          TX packets:160 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1 
          RX bytes:11840 (11.8 KB)  TX bytes:11840 (11.8 KB)
hlp@ubuntu:~$ cat /etc/network/interfaces
# 这里省略前面的固定内容
# 原本是ens33  发现修改虚拟机配置文件vmx后,网卡变化,对应也修改 
auto ens160
iface ens160 inet dhcp

auto ens38
iface ens38 inet dhcp

查看支持多网卡状况:(这里我设置了8核处理器,所以这个8个队列(0-7))

hlp@ubuntu:~$ cat /proc/interrupts |grep ens
 16:          3   0    1169          0         12          4          0          0   IO-APIC  16-fasteoi   vmwgfx, snd_ens1371, ens38
 57:          3   766  0          0          0          0          0          0   PCI-MSI 1572864-edge      ens160-rxtx-0
 58:          0   1    0          0          0          0          0          0   PCI-MSI 1572865-edge      ens160-rxtx-1
 59:          0   0    0          0          0          0          0          0   PCI-MSI 1572866-edge      ens160-rxtx-2
 60:          0   0    0          0          0          4          0          0   PCI-MSI 1572867-edge      ens160-rxtx-3
 61:          0   0    0          0          1          3          0          0   PCI-MSI 1572868-edge      ens160-rxtx-4
 62:          0   0    0          0          0          0          0          0   PCI-MSI 1572869-edge      ens160-rxtx-5
 63:          0   0    0          0          0          0          0          0   PCI-MSI 1572870-edge      ens160-rxtx-6
 64:          0   0    0          0          0          1          0          0   PCI-MSI 1572871-edge      ens160-rxtx-7
 65:          0   0    0          0          0          0          0          0   PCI-MSI 1572872-edge      ens160-event-8
5:用nginx测试一下多队列网卡:

安装nginx,并进行启动测试: 参考上一篇文章。(多个网卡都可以启动测试成功)

配置nginx亲和性,根据终端号,配置和cpu的绑定,并进行测试。

#这次我定义的8核,所以在nginx的配置文件中设置8个进程以及cpu亲缘性如下:
worker_processes  8;
worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;
#从/proc/interrupts 文件中可以看到,多队列网卡0-7,对应的中断号是 57-64 
#设置对应中断号与cpu的绑定, 直接查看,发现cat /proc/irq/64/smp_affinity_list 每个对应的cpu是均匀的,可以直接测试一下
#使用wrk性能测试工具进行测试    ./wrk -c400 -d60s -t100 http://192.168.50.58/

#对比中断号和cpu的接收,可以发现,下面中断号对应cpu和我们查看interrupts中中断效果大体一致 
#smp_affinity_list 中cpu的绑定,可以通过修改smp_affinity文件实现,用echo写入,可以参考上一篇文章
hlp@ubuntu:~$ cat /proc/interrupts |grep ens
	 CPU0 CPU1    CPU2       CPU3     CPU4   CPU5       CPU6       CPU7
 16:    3   0    10450         17      169     10          0         97   IO-APIC  16-fasteoi   vmwgfx, snd_ens1371, ens38
 57:    3   256600   0          0        0      0          0          0   PCI-MSI 1572864-edge      ens160-rxtx-0
 58:    0   1        0          0        0      0          0      57505   PCI-MSI 1572865-edge      ens160-rxtx-1
 59:    0   1        0          0        0      0      56837          0   PCI-MSI 1572866-edge      ens160-rxtx-2
 60:    0   0        0      20167        0  34379          0          0   PCI-MSI 1572867-edge      ens160-rxtx-3
 61:    0   0        0          0    49059      3          0          0   PCI-MSI 1572868-edge      ens160-rxtx-4
 62:    0   1        0      53576        0      0          0          0   PCI-MSI 1572869-edge      ens160-rxtx-5
 63:    0   1    53047          0        0      0          0          0   PCI-MSI 1572870-edge      ens160-rxtx-6
 64:    0   4047     0          0        0  53545          0          0   PCI-MSI 1572871-edge      ens160-rxtx-7
 65:    0   0        0          0        0     0           0          0   PCI-MSI 1572872-edge      ens160-event-8
root@ubuntu:/usr/local/nginx# cat /proc/irq/56/smp_affinity_list 
5
root@ubuntu:/usr/local/nginx# cat /proc/irq/57/smp_affinity_list 
1
root@ubuntu:/usr/local/nginx# cat /proc/irq/58/smp_affinity_list 
7
root@ubuntu:/usr/local/nginx# cat /proc/irq/59/smp_affinity_list 
6
root@ubuntu:/usr/local/nginx# cat /proc/irq/60/smp_affinity_list 
3
root@ubuntu:/usr/local/nginx# cat /proc/irq/61/smp_affinity_list 
4
root@ubuntu:/usr/local/nginx# cat /proc/irq/62/smp_affinity_list 
3
root@ubuntu:/usr/local/nginx# cat /proc/irq/63/smp_affinity_list 
2
root@ubuntu:/usr/local/nginx# cat /proc/irq/64/smp_affinity_list 
5

如果我增加大内存页和隔离cpu,试一下,这里没有手动设置这个中断与cpu核的绑定,可以参考上一篇文章

#这里是虚拟机  在/etc/default/grub中对应字段增加:
	default_hugepages=1G hugepagesz=2M hugepages=1024 isolcpus=0-2
#执行update-grub重启生效
#重启后查看多队列网卡绑定情况:
root@ubuntu:/usr/local/nginx# cat /proc/irq/56/smp_affinity_list 
7
root@ubuntu:/usr/local/nginx# cat /proc/irq/57/smp_affinity_list 
6
root@ubuntu:/usr/local/nginx# cat /proc/irq/58/smp_affinity_list 
5
root@ubuntu:/usr/local/nginx# cat /proc/irq/59/smp_affinity_list 
4
root@ubuntu:/usr/local/nginx# cat /proc/irq/60/smp_affinity_list 
3
root@ubuntu:/usr/local/nginx# cat /proc/irq/61/smp_affinity_list    #这个好像会变,测试前是6,测试后是3
3
root@ubuntu:/usr/local/nginx# cat /proc/irq/62/smp_affinity_list 
6
root@ubuntu:/usr/local/nginx# cat /proc/irq/63/smp_affinity_list 
5
hlp@ubuntu:~$ tail -f /proc/interrupts |grep ens
tail: /proc/interrupts: file truncated
 16:          8       0    0   13     0    39    358          2   IO-APIC  16-fasteoi   vmwgfx, snd_ens1371, ens38
 56:         91       0    0    0     0     0      2       1468   PCI-MSI 1572864-edge      ens160-rxtx-0
 57:          0       0    0    0     0     0      0          0   PCI-MSI 1572865-edge      ens160-rxtx-1
 58:          0       0    0    0     0     0      0          0   PCI-MSI 1572866-edge      ens160-rxtx-2
 59:          0       0    0    0     0     0      0          0   PCI-MSI 1572867-edge      ens160-rxtx-3
 60:          0       0    0    0     0     0      1          0   PCI-MSI 1572868-edge      ens160-rxtx-4
 61:          0       0    0    0     0     0      2          3   PCI-MSI 1572869-edge      ens160-rxtx-5
 62:          1       0    0    0     0     1      4          2   PCI-MSI 1572870-edge      ens160-rxtx-6
 63:          0       0    0    0     0     0      0          0   PCI-MSI 1572871-edge      ens160-rxtx-7
 64:          0       0    0    0     0     0      0          0   PCI-MSI 1572872-edge      ens160-event-8
#启动nginx并进行测试:
hlp@ubuntu:~$ cat /proc/interrupts |grep ens
		CPU0  CPU1 CPU2    CPU3   CPU4       CPU5       CPU6       CPU7
 16:      8     0    0      13     304         39       1369          2   IO-APIC  16-fasteoi   vmwgfx, snd_ens1371, ens38
 56:     91     0    0       0       0          0          2      93813   PCI-MSI 1572864-edge      ens160-rxtx-0
 57:      0     0    0       0       0          0      35083          1   PCI-MSI 1572865-edge      ens160-rxtx-1
 58:      0     0    0       0       0      32895          0          1   PCI-MSI 1572866-edge      ens160-rxtx-2
 59:      0     0    0       0   38237          0          0          1   PCI-MSI 1572867-edge      ens160-rxtx-3
 60:      0     0    0   34352       0          0          1          1   PCI-MSI 1572868-edge      ens160-rxtx-4
 61:      0     0    0   25975       0          0          2       3541   PCI-MSI 1572869-edge      ens160-rxtx-5
 62:      1     0    0       0       0          1      33745          2   PCI-MSI 1572870-edge      ens160-rxtx-6
 63:      0     0    0       0       0      35065          0          1   PCI-MSI 1572871-edge      ens160-rxtx-7
 64:      0     0    0       0       0          0          0          0   PCI-MSI 1572872-edge      ens160-event-8

2:(失败)编译dpdk(环境用成了镜像32位的,最后一个报错没解决)

1:切换到root权限执行吧。

2:dpdk的编译主要依赖脚本./usertools/dpdk-setup.sh,执行该脚本,可以根据描述依次来实现编译。

如果用39,报错,环境问题,没注意到我的虚拟机环境安装的32位的,镜像选错了,查找对应的32位版本,是27,试一下。

#报错/usr/include/features.h:367:25: fatal error: sys/cdefs.h: No such file or directory

#查看正常环境的文件
root@ubuntu:/# find -name cdefs.h
./home/ubuntu/0407_AT/openwrt-sdk-ramips-mt7621_gcc-7.4.0_musl.Linux-x86_64/staging_dir/toolchain-mipsel_24kc_gcc-7.4.0_musl/include/sys/cdefs.h
./usr/include/x86_64-linux-gnu/sys/cdefs.h
#我的环境上的文件
hlp@ubuntu:/$ sudo find -name cdefs.h
./usr/include/i386-linux-gnu/sys/cdefs.h
#才注意到我的环境安装的是32位的。。。

这里发现有32的版本,试一下,执行27

#报错 eal_memory.c:32:18: fatal error: numa.h: No such file or directory
 sudo apt-get install libnuma-dev
 #执行27 编译i686的包,编译成功但是会报 Installation cannot run with T defined and DESTDIR undefined
 #这里只是编译,不影响

设置环境变量:

#注意观察编译过程 其实会提示的  同时 注意后面的内容是自己环境对应的安装目录和编译环境
root@ubuntu:/home/hlp/dpdk/dpdk-stable-19.08.2# export RTE_SDK=/home/hlp/dpdk/dpdk-stable-19.08.2
root@ubuntu:/home/hlp/dpdk/dpdk-stable-19.08.2# export RTE_TARGET=i686-native-linux-gcc

执行testpmd

#执行43  插入IGB_UIO模块,选择网卡“vmxnet3”会加载此模块
#执行44  插入VFIO模块,选择网卡"e1000"会加载这个模块
#执行49  插入igb_uio模块,绑定网卡,注意绑定的网卡id
Option: 49
Network devices using kernel driver
===================================
0000:02:06.0 '79c970 [PCnet32 LANCE] 2000' if=ens38 drv=pcnet32 unused=igb_uio,vfio-pci *Active*
0000:03:00.0 'VMXNET3 Ethernet Controller 07b0' if=ens160 drv=vmxnet3 unused=igb_uio,vfio-pci *Active*

No 'Baseband' devices detected
==============================

No 'Crypto' devices detected
============================

No 'Eventdev' devices detected
==============================

No 'Mempool' devices detected
=============================

No 'Compress' devices detected
==============================

No 'Misc (rawdev)' devices detected
===================================
#注意上面会打印网卡信息,输入要绑定的网卡编号 这里是0000:03:00.0
Enter PCI address of device to bind to IGB UIO driver: 0000:03:00.0

#会提示警告  说网卡正在运行,可以关闭对应要配置的网卡,重新执行
sudo ifconfig ens160 down
#执行53  选择7,
#会报错error allocating rte services array 
bitmask: 7
Launching app
EAL: Detected 4 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'PA'
EAL: Probing VFIO support...
EAL: VFIO support initialized
error allocating rte services array
EAL: FATAL: rte_service_init() failed
EAL: rte_service_init() failed
EAL: Error - exiting with code: 1
  Cause: Cannot init EAL: Exec format error
#可能与大内存页配置有关   可以查看当前的大内存页
root@ubuntu:/home/hlp/dpdk/dpdk-stable-19.08.2# grep Huge /proc/meminfo 
AnonHugePages:         0 kB
HugePages_Total:    1024
HugePages_Free:     1024
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB

最终,我还是没有测试成功,卡死在运行测试程序时,报错

hlp@ubuntu:~/dpdk/dpdk-stable-19.08.2/i686-native-linux-gcc$ sudo ./app/testpmd i
EAL: Detected 4 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'PA'
EAL: Probing VFIO support...
EAL: VFIO support initialized
error allocating rte services array
EAL: FATAL: rte_service_init() failed
EAL: rte_service_init() failed
EAL: Error - exiting with code: 1
  Cause: Cannot init EAL: Exec format error

2:(成功)使用amd64虚拟机进行测试

环境用的ubuntu16.04 +dpdk 19.08.2

1:安装环境,配置多网卡,安装gcc,python。

2:配置大内存页(如果启动不起来,虚拟机内存设大一点),安装dpdk

安装libnuma-dev(numa.h需要)

执行对应的环境安装 这里是39, x86_64-native-linux-gcc

配置环境变量: export RTE_SDK=/home/hlp/dpdk/dpdk-stable-19.08.2

export RTE_TARGET=x86_64-native-linux-gcc

#执行43 插入IGB_UIO模块,选择网卡“vmxnet3”会加载此模块

#执行44 插入VFIO模块,选择网卡"e1000"会加载这个模块

#执行49 插入igb_uio模块,绑定网卡,注意绑定的网卡id

#执行53 执行testpmd

Option: 53


  Enter hex bitmask of cores to execute testpmd app on
  Example: to execute app on cores 0 to 7, enter 0xff
bitmask: 7
Launching app
EAL: Detected 4 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'PA'
EAL: No available hugepages reported in hugepages-1048576kB
EAL: Probing VFIO support...
EAL: VFIO support initialized
EAL: PCI device 0000:02:06.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 8086:100f net_e1000_em
EAL: PCI device 0000:03:00.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 15ad:7b0 net_vmxnet3
testpmd: No probed ethernet devices
Interactive-mode selected
testpmd: create a new mbuf pool <mbuf_pool_socket_0>: n=163456, size=2176, socket=0
testpmd: preferred mempool ops selected: ring_mp_mc
Done

折腾折腾还专门把网卡改为eth系列,以为是网卡驱动的问题,原来是49没有绑定网卡成功导致

最后发现,执行成功

Option: 53


  Enter hex bitmask of cores to execute testpmd app on
  Example: to execute app on cores 0 to 7, enter 0xff
bitmask: 7
Launching app
EAL: Detected 4 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'PA'
EAL: No available hugepages reported in hugepages-1048576kB
EAL: Probing VFIO support...
EAL: VFIO support initialized
EAL: PCI device 0000:02:06.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 8086:100f net_e1000_em
EAL: PCI device 0000:03:00.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 15ad:7b0 net_vmxnet3
Interactive-mode selected
testpmd: create a new mbuf pool <mbuf_pool_socket_0>: n=163456, size=2176, socket=0
testpmd: preferred mempool ops selected: ring_mp_mc

Warning! port-topology=paired and odd forward ports number, the last port will pair with itself.

Configuring Port 0 (socket 0)
Port 0: 00:0C:29:71:A2:F2
Checking link statuses...
Done
testpmd> show port info 0

********************* Infos for port 0  *********************
MAC address: 00:0C:29:71:A2:F2
Device name: 0000:03:00.0
Driver name: net_vmxnet3
Connect to socket: 0
memory allocation on the socket: 0
Link status: up
Link speed: 10000 Mbps
Link duplex: full-duplex
MTU: 1500
Promiscuous mode: enabled
Allmulticast mode: disabled
Maximum number of MAC addresses: 1
Maximum number of MAC addresses of hash filtering: 0
VLAN offload: 
  strip off 
  filter off 
  qinq(extend) off 
Supported RSS offload flow types:
  ipv4
  ipv4-tcp
  ipv6
  ipv6-tcp
Minimum size of RX buffer: 1646
Maximum configurable length of RX packet: 16384
Current number of RX queues: 1
Max possible RX queues: 16
Max possible number of RXDs per queue: 4096
Min possible number of RXDs per queue: 128
RXDs number alignment: 1
Current number of TX queues: 1
Max possible TX queues: 8
Max possible number of TXDs per queue: 4096
Min possible number of TXDs per queue: 512
TXDs number alignment: 1
Max segment number per packet: 255
Max segment number per MTU/TSO: 16

3:运行dpdk测试demo

运行dpdk环境下的helloworld测试:

root@ubuntu:/home/hlp/dpdk/dpdk-stable-19.08.2/examples/helloworld# make
/bin/sh: 1: pkg-config: not found
/bin/sh: 1: pkg-config: not found
  CC main.o
  LD helloworld
  INSTALL-APP helloworld
  INSTALL-MAP helloworld.map
root@ubuntu:/home/hlp/dpdk/dpdk-stable-19.08.2/examples/helloworld# ./build/helloworld -l 0-3 -n 4
EAL: Detected 4 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'PA'
EAL: No available hugepages reported in hugepages-1048576kB
EAL: Probing VFIO support...
EAL: VFIO support initialized
EAL: PCI device 0000:02:06.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 8086:100f net_e1000_em
EAL: PCI device 0000:03:00.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 15ad:7b0 net_vmxnet3
hello from core 1
hello from core 2
hello from core 3
hello from core 0

改成8个核心,测试一下:

注意配置环境变量。重新执行49的绑定(注意执行成功,需要关闭要绑定的网卡),53测试testpmd成功。

helloworld测试:

root@ubuntu:/home/hlp/dpdk/dpdk-stable-19.08.2/examples/helloworld# ./build/helloworld -l 0-7 -n 8
EAL: Detected 8 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'PA'
EAL: No available hugepages reported in hugepages-1048576kB
EAL: Probing VFIO support...
EAL: VFIO support initialized
EAL: PCI device 0000:02:06.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 8086:100f net_e1000_em
EAL: PCI device 0000:03:00.0 on NUMA socket -1
EAL:   Invalid NUMA socket, default to 0
EAL:   probe driver: 15ad:7b0 net_vmxnet3
hello from core 1
hello from core 2
hello from core 3
hello from core 4
hello from core 5
hello from core 6
hello from core 7
hello from core 0

l3fwd测试和kni测试,待补充:

4:回顾一下注意事项:

1:处理器配置成多个,多队列网卡的队列数就是多少个,配置多网卡,方便调试(用的虚拟机)。
2:要修改虚拟机vmx配置文件,使其支持多队列网卡,在/proc/interrupts中查看对应多队列网卡是否生效。
3:配置大内存页后,有时候虚拟机会启动不起来,需要增大虚拟机内存。
4:修改grub文件后一定要执行 update-grub 并重启生效

多个网卡的生效在 /etc/network/interfaces中配置,并重启网络服务生效。

配置修改成传统的网卡名/配置大内存页/隔离cpu 在**/etc/default/grub**中配置

5:编译dpdk时,要注意自己的环境,选择对应的环境编译

我装虚拟机没注意,32位的,编译64位的dpdk报头文件找不到才发现

6:dpdk编译时不要忘记配置环境变量
7:dpdk编译时执行49,要注意执行成功,这里要关闭对应绑定的网卡(ifconfig xxx down)
8:dpdk编译时报错,numa.h找不到,安装libnuma-dev
9:dpdk编译时执行53 testpmd测试时,如果执行不成功(testpmd: No probed ethernet devices),是因为执行49网卡绑定不成功导致的