如何获得dpdk来识别Linux虚拟化的NIC?
收藏

我的机器上有两个物理网卡。
基于this post,dpdk似乎应该能够使用虚拟nics。
因此,我在linux中使用以下命令创建了3个虚拟接口,其中eno1d1是物理nic的名称。

sudo ifconfig eno1d1:0 10.10.1.107
sudo ifconfig eno1d1:1 10.10.1.207
sudo ifconfig eno1d1:2 10.10.2.107

但是,当我运行dpdk应用程序时,函数rte_eth_dev_count仍然只返回2。
我需要做什么才能让dpdk识别虚拟网卡?
这里有一些关于我的dpdk版本的信息,它记录在我的应用程序的开头。
Using DPDK version DPDK 16.11.0
DPDK: EAL: Detected 16 lcore(s)
DPDK: EAL: Probing VFIO support...
DPDK: EAL: PCI device 0000:09:00.0 on NUMA socket 0
DPDK: EAL:   probe driver: 15b3:1007 net_mlx4
DPDK: PMD: net_mlx4: PCI information matches, using device "mlx4_0" (VF: false)
DPDK: PMD: net_mlx4: 2 port(s) detected
DPDK: PMD: net_mlx4: port 1 MAC address is ec:b1:d7:85:3a:12
DPDK: PMD: net_mlx4: port 2 MAC address is ec:b1:d7:85:3a:13
DPDK: PMD: net_mlx4: 0xae6000: TX queues number update: 0 -> 1
DPDK: PMD: net_mlx4: 0xae6000: RX queues number update: 0 -> 1

这是我机器上的输出。
eno1      Link encap:Ethernet  HWaddr ec:b1:d7:85:1a:12  
          inet addr:128.110.153.148  Bcast:128.110.155.255  Mask:255.255.252.0
          inet6 addr: fe80::eeb1:d7ff:fe85:1a12/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:15241610 errors:0 dropped:0 overruns:0 frame:0
          TX packets:11238825 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:4530541723 (4.5 GB)  TX bytes:8168066799 (8.1 GB)

eno1d1    Link encap:Ethernet  HWaddr ec:b1:d7:85:1a:13  
          inet addr:10.10.1.7  Bcast:10.10.1.255  Mask:255.255.255.0
          inet6 addr: fe80::eeb1:d7ff:fe85:1a13/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:3787661978 errors:0 dropped:66084 overruns:0 frame:0
          TX packets:4758273664 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:1905977969665 (1.9 TB)  TX bytes:3897938668285 (3.8 TB)

eno1d1:0  Link encap:Ethernet  HWaddr ec:b1:d7:85:1a:13  
          inet addr:10.10.1.107  Bcast:10.255.255.255  Mask:255.0.0.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

eno1d1:1  Link encap:Ethernet  HWaddr ec:b1:d7:85:1a:13  
          inet addr:10.10.1.207  Bcast:10.255.255.255  Mask:255.0.0.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

eno1d1:2  Link encap:Ethernet  HWaddr ec:b1:d7:85:1a:13  
          inet addr:10.10.2.107  Bcast:10.255.255.255  Mask:255.0.0.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

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:62313 errors:0 dropped:0 overruns:0 frame:0
          TX packets:62313 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1 
          RX bytes:3557508 (3.5 MB)  TX bytes:3557508 (3.5 MB)


最佳答案:

ENO1D1:0链路ENCAP:以太网Hwaddr EC:B1:D7:85:1A:13
这些不是虚拟网卡,而是网络别名,即不同的Linux内核引用同一个网卡。由于dpdk不使用linux内核,因此我们不能使用这些别名来运行dpdk应用程序。
尽管如此,我们在不使用物理NIC的情况下运行DPDK应用程序的选项很少:
在虚拟机中运行dpdk
使用所需数量的NIC运行虚拟机。
在虚拟机内部,将NIC绑定到uio。
在虚拟机中,运行dpdk,它应该可以与虚拟机中的nics一起正常工作。
有关更多信息,请查看DPDK Poll Mode Driver for Emulated Virtio NIC
使用NIC虚拟函数:
在主机上配置SR-IOV支持。
在主机nicpassing netdev to the MLX4 kernel module driver上配置少量虚拟功能。
在主机上,将几个niv虚拟函数绑定到num_vfs
在主机上,运行dpdk,它应该可以正常运行nic虚拟函数。
有关详细信息,请查看DPDK MLX4 Poll Mode DriverHowTo Configure SR-IOV for ConnectX-3
对于SR-IOV的一般描述,您可能会发现有用的DPDK Intel Virtual Function Driver。请注意,mellanox内核模块的配置略有不同,您应该改为使用上面链接中描述的vfio-pci
使用dpdk虚拟设备
使用num_vfs支持编译dpdk。
将主机配置为像往常一样运行DPDK应用程序(即启用大页面等)。
不要将任何NIC绑定到uio。
创建几个tun/tap接口,用物理nic桥接它们。
像往常一样运行一个dpdk应用程序,但是传递几个libpcap参数来创建很少的虚拟设备,例如:
测试PMD-L 0-3-N 4\
--vdev'net_pcap0,iface=tun0'--vdev'net_pcap1,iface=tun1'…
有关更多信息,请查看DPDK libpcap Poll Mode Driver
希望其中一个能满足你的需要。

公众号