初识DPDK

1.什么是DPDK?

数据平面开发套件(DPDK [1]  ,Data Plane Development Kit)是由6WIND,Intel等多家公司开发,主要基于Linux系统运行,用于快
速数据包处理的函数库与驱动集合,可以极大提高数据处理性能和吞吐量,提高数据平面应用程序的工作效率。

2.关于DPDK的很多问题

1.为什么有了netmap之后还要有DPDK呢?
  因为netmap还是不能满足我们日益增长的需求.

3.其他的闲谈(与dpdk无关)

virtualDev="eth1000"--不支持多队列网卡
virtualDev="vmxnet3"--支持多队列网卡
wakeOnPcktRcv="TRUE"

改变默认网卡的起始位置:/etc/default/grub 改动网卡net.ifnames=0 biosdevname=0
我的centos山没有起作用,可以再试试,这样配置之后里面了上就可以从0号开始配置网卡信息,
但我的网卡还是:
ens160
ens192
ens224
ens256

重启网络:
service network restart

缺页和不命中


巨页的作用是为了减少置换的次数,不能解决缺页的问题.
设置的是内存中没有时去磁盘中去寻找数据的大小和粒度.


将e1000改成vmxnet3
添加网卡后,nmcli可以自动生成网卡信息.



cat /proc/interrupts          查看所有的中断信息
grep ens160  /proc/interrupts 查看网卡ens160的中断信息
cat /proc/cpuinfo 查看cpu的信息

cat /proc/irq/58/smp_affinity

其中58是中断号

设置亲缘性:
echo 00000001 > /proc/irq/58/smp_affinity
echo 00000002 > /proc/irq/59/smp_affinity
echo 00000004 > /proc/irq/60/smp_affinity
echo 00000008 > /proc/irq/61/smp_affinity
echo 00000010 > /proc/irq/62/smp_affinity
echo 00000020 > /proc/irq/63/smp_affinity
echo 00000040 > /proc/irq/64/smp_affinity
echo 00000080 > /proc/irq/65/smp_affinity

进行压力测试:
./wrk -c400 -d60 -t100 http://192.168.118.141:8081/





4.配置dpdk环境


1.下载dpdk的安装包
https://core.dpdk.org/download/
可以选择一个您喜欢的版本,我选择的是19.08.2

2.解压dpdk
$xz -d dpdk-19.08.2.tar.xz
$tar xvf dpdk-19.08.2.tar

3.到/home/share/dpdk/dpdk-stable-19.08.2/usertools目录下(这个是我自己的目录,灵活调整)执行:
dpdk-setup.sh
第一步:选择您编译时所需要的的系统
选择系统的时候我选择的是:39(64位gcc)

第二步:Set Linux Env(设置linux环境)
export RTE_SDK=/home/share/dpdk/dpdk-stable-19.08.2/
export RTE_TARGET=x86_64-native-linux-gcc
echo $RTE_TARGET查看是否设置成功
echo $RTE_SDK查看是否设置成功
执行dpdk-setup.sh
选择43,44,45,47,49

47 为NUMA系统设置大页内存映射,提示中说可以设置64,建议设置成512个,否则在53做测试的时候会
报错:
运行testpmd报错Cause: rte_zmalloc(32 struct rte_port) failed [已关闭],
此时改成512就可以了.
 

49的时候报错:
0000:02:01.0 '82545EM Gigabit Ethernet Controller (Copper) 100f' if=ens33 drv=e1000 unused=igb_uio,vfio-pci 


Enter PCI address of device to bind to IGB UIO driver: 0000:0b:00.0
Warning: routing table indicates that interface 0000:0b:00.0 is active. Not modifying
OK
ifconfig eth0 down

选择53进行测试:
show port info 0

vim /etc/default/grub
net.ifnames=0 biosdevname=0 default_hugepagesz=1G hugepagesz=2M hugepages=1024 isolcpus=0-2


quit退出测试




说明一些编译步骤:
--------------------------------------------------
[43] Insert IGB UIO module--插入IGB模块(IGB是网卡驱动模块)
[44] Insert VFIO module   --插入VFIO模块(比IGB安全的网卡驱动模块)
[45] Insert KNI module    --插入内核网络接口模块
[46] Setup hugepage mappings for non-NUMA systems--non-NUMA,对于CPU使用内存而言,有同一编码和非同一编码,比如有4096byte,
non-NUMA就是非同一的每次都是从0开始访问内存,如果分成四块内存,四块都是0-1023,,NUMA则是0-1023,1024-2047,2048-3071,3072-4095;
non-NUMA比NUMA方式更灵活些.

[47] Setup hugepage mappings for NUMA systems--为NUMA系统设置大页内存映射
[48] Display current Ethernet/Baseband/Crypto device settings
[49] Bind Ethernet/Baseband/Crypto device to IGB UIO module
[50] Bind Ethernet/Baseband/Crypto device to VFIO module
[51] Setup VFIO permissions

4.编译成功之后生成
  /home/share/dpdk/dpdk-stable-19.08.2/x86_64-native-linux-gcc

5.


6.测试helloworld
gcc -o helloword main.c -I /user/local/include/dpdk -ldpdk -lnuma -lpthred -ldl

  
/home/share/dpdk/dpdk-stable-19.08.2/x86_64-native-linux-gcc/lib

5.dpdk的一些作用作用

1.dpdk可以提供接口让用户定义我们的代码在哪个CPU上执行;
  ./helloworl -l 2,3
  ./helloworl -l 0-4

6.dpdk的一些开源应用

mydpdkdns(对版本依赖比较严重,支持dpdk17.02.1)
eth0->vEth0
会先把eth0关掉,然后插入一个新的虚拟网卡vEth0,两者的mac地址是不一样的
ifconfig vEth0 192.168.1.188 hw ether 52:54:00:90:f2:88 up
 

 

 

 

 

 

 

©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页