如果你已经安装pf_ring,你可能需要执行:
rmmod pf_ring
如果你不确定你是否安装pf_ring,执行:
modinfo pf_ring
进入到kernel文件夹中make和make install
# tar -zxf PF_RING.4.7.0.tar.gz
# cd PF_RING.4.7.0/
# make //直接在跟目录下面make,进行全部编译
# cd PF_RING.4.7.0/kernel
# make
# sudo make install //内核安装需要root用户权限
切换到/lib/modules//kernel/net目录,可以看到有pf_ring目录,进入pf_ring目录
执行sudo insmod pf_ring.ko transparent_mode=1
//最好设置一下,官方解释是2的性能最好,但是有大神测试后发现差别并不是很大
当PF_RING激活时,会创建/proc/net/pf_ring目录,使用cat命令查看pf_ring的属性信息:
# cat /proc/net/pf_ring/info
注:为了编译PF_RING内核模块,你需要安装Linux内核的头文件(或者内核源代码)。本人测试过2.6.X的内核,是可以编译过的
进入到用户空间库userland/lib下,编译和安装。
# cd ../userland/lib
# ./configure
# make
# sodu make install
如果需要使用libpcap抓包分析,请卸载之前安装的libpcap,然后进入/userland/libpcap-xxx-ring/目录下配置、编译和安装驱动。
卸载原来的libpcap:
# rpm -qa libpcap //查看安装的libpcap,如果有libpcap则强制卸载
# rpm --nodeps -e libpcap //按照原文的报错,没有--nodefs选项,使用的是--nodeps,不验证包依赖性, –e 选项,意思是擦除erase
安装pf_ring的libpcap:
# cd ../libpcap
# ./configure
# make
# sudo make install
注:为了使用PF_RING的优点,请使用PF_RING使能的libpcap.a重新编译应用。
进入到drivers目录下,根据ethtool -i ethx命令查看的网卡类型和驱动进入指定的目录进行编译和安装。
# cd /root/soft/PF_RING/PF_RING-5.6.2/drivers/PF_RING_aware/intel/e1000e/e1000e-2.0.0.1/src
# make
# sodu make install
安装网卡驱动,进入到目录lib/modules//kernel/drivers/net下进行网卡驱动安装。
# sodu insmod e1000e.ko //安装pf_ring网卡驱动
# sodu modprobe e1000e //只能载入/lib/modules//中模块
进入到userland/examples目录编译例子程序。
# cd /userland/examples
# make
# ./pfcount -i eth0 //捕获eth0网口的数据报文
注:使用drivers/intel/ixgbe下的驱动(支持DNA的ixgbe驱动的网卡)+DNA驱动技术可以达到线速采集,PF_RING模块必须在DNA驱动之前加载。
1.pf_ring.ko模块加载错误
错误信息:insmod: error inserting 'pf_ring.ko': -1 Unknown symbol in module
解决方法:没有卸载当前的网卡驱动,新的加载不了,需要卸载网卡驱动
2. 编译网卡模块驱动错误
驱动所在目录:/root/soft/PF_RING/PF_RING-5.6.2/drivers/PF_RING_aware/intel/e1000e/e1000e-2.0.0.1/src
错误信息:/root/soft/PF_RING/PF_RING-5.6.2/drivers/PF_RING_aware/intel/e1000e/e1000e-2.0.0.1/src/kcompat.h:3039: error: conflicting types for ‘netdev_features_t’
解决方法:vim kcompat.h +3039 // 注释掉第3039行
3. 网卡驱动模块所在目录:/root/soft/PF_RING/PF_RING-5.6.2/drivers/PF_RING_aware/intel/e1000e/e1000e-2.0.0.1/src
加载网卡驱动模块:insmod e1000e.ko