build TCPDump for current host

step1、安装依赖

所有时Terminal + Shell + GNU CoreUtils
下载时cURL
解压时tar + gzip
编译时gmakegcc / GCC | Clang / LLVM
运行时glibc ( libc.sold-linux-x86-64.so )

step2、使用curl命令下载TCPDump源码包 (

curl -LO http://www.tcpdump.org/release/tcpdump-4.9.3.tar.gz

step3、使用tar解压TCPDump源码包

tar vxf tcpdump-4.9.3.tar.gz

step4、进入TCPDump-4.9.3目录

cd TCPDump-4.9.3

step5、查看TCPDump-4.9.3目录中的内容

step6、创建构建目录,并进入该目录

mkdir build && cd build

step7、使用../configure配置编译参数

../configure是一个可执行的POSIX sh脚本,用它 配置后会产生gmake的配置文件Makefile

../configure的使用格式如下:

./configure [option]... [VAR=VALUE]...
option说明
--help    | -h查看../configure的使用帮助
--version | -V查看../configure是哪个版本的autoconf生成的
--quiet   | -q | --silent不输出checking...这些信息
--prefix=DIR指定安装目录。默认是/usr/local/
--host=HOST
设置目标程序运行的CPU平台
一般不需要设置,除非你想要交叉编译
默认与与宿主机一样
--enable-FEATURE[=yes|no]
yes:开启FEATURE
no :关闭FEATURE
--enable-option-checking[=yes|no]是否检查有无不认识的--enable-FEATURE--with-PACKAGE参数
--enable-smb[=yes|no]是否开启smb
--disable-universaldon't build universal on OS X
--with-PACKAGE[=yes|no]
yes: 使用PACKAGE
no:不使用PACKAGE
--without-gcc不使用GCC
--with-smi是否使用libsmi
--with-system-libpcap不使用topsrc/libpcap中的libpcap
--with-crypto[=DIR]是否使用OpenSSL,如果设置了DIR,在DIR/{include,lib}中搜索其头文件库文件
--with-cap-ng是否使用libcap
VARVALUE示例说明
CCgcc |  clang指定C编译器
CFLAGS-O2 -v指定C编译器的参数
CPPcpp指定C预处理器
CPPFLAGS-I<includeDIR>指定C预处理器的参数
LDFLAGS-L<libDIR>指定C链接器的参数
LIBS-l<libName>指定C链接器要链接的库的名称

示例:

../configure --prefix=/usr CFLAGS='-O2 -v'

step8、使用make进行编译、安装

make && sudo make install