TCPCOPY 1.0 安装使用
上一篇 /
下一篇 2016-09-09 15:24:18
/ 个人分类:linux
简介TCPCOPY 是一个 tcp 流量的实时复制工具,其1.0版本由网易工程师 @tcpcopy 开发和维护。一般用来将生产环境的线上流量实时复制到测试环境进行测试。例如新系统上线前,如果我们希望进行一些基本的压力测试,那么我们可以直接利用 tcpcopy 来复制线上的流量过来对系统进行测试,这样的好处是测试数据接近真实水平,且实施起来相对简单。二,安装测试中用到的3台服务器信息如下:线上服务器 online server 内网IP地址 192.168.0.8/24 外网IP 214.167.0.8/28测试服务器 test server 内网IP地址 192.168.0.230/24 外网IP 214.167.0.13/28辅助服务器 assistant server 内网IP地址 192.168.0.219/24 外网IP 214.167.1.76/24192.168.0.8是线上服务器,192.168.0.230和192.168.0.219是测试环境。我们在192.168.0.8上运行tcpcopy把线上流量拷贝到192.168.0.230,在192.168.0.230上我们通过路由将应答转向192.168.0.219,在192.168.0.219上把应答丢弃。第一步,在 online server 192.168.0.8上安装并运行 tcpcopy daemon :我们从github上下载1.0版本的源码包;wget https://github.com/session-replay-tools/tcpcopy/archive/1.0.0.tar.gz -O tcpcopy-1.0.0.tar.gz安装依赖包;yum -y install libpcap-devel解压编译和安装;tar zxvf tcpcopy-1.0.0.tar.gzcd tcpcopy-1.0.0./configure (默认raw socket方式抓包)make make install最后运行 tcpcopy;/usr/local/tcpcopy/sbin/tcpcopy -x 80-192.168.0.230:80 -s 192.168.0.219 -c 10.10.10.x -d -C 4 -l tcpcopy.log -P /var/run/tcpcopy.pid指令说明:-x 80-192.168.0.230:80将本机上80端口的流量复制到192.168.0.230(测试服务器)的80端口-s指定intercept进程所在的服务器192.168.0.219。(丢包服务器)-c修改请求的host地址为10.10.10.x,以便在230测试服务器上设置路由(设置路由是为了将应答转向丢219包服务器)-C 开启4个进程-d 以daemon形式运行-l 记录日志-P 记录pid其他参数可以通过/usr/local/tcpcopy/sbin/tcpcopy -h查看成功运行后可以观察到的网路连接状态:#ss -an|grep 192.168.0.219ESTAB 0 0 192.168.0.8:49034 192.168.0.219:36524 ESTAB 0 0 192.168.0.8:49035 192.168.0.219:36524 ESTAB 0 0 192.168.0.8:49032 192.168.0.219:36524 ESTAB 0 0 192.168.0.8:49033 192.168.0.219:36524 第二步,在 auxiliary server 192.168.0.219上安装并运行 intercept daemon :从github上下载1.0版本的源码包;wget https://github.com/session-replay-tools/intercept/archive/1.0.0.tar.gz -O intercept-1.0.0.tar.gz安装依赖包;yum -y install libpcap-devel(CentOS6系统直接yum安装即可1.4版本)注意CentOS5系统libpcap-devel版本是libpcap-devel-0.9.4-15.el5,intercept-1.0需要libcap-devel1.4以上版本此时需要源码包安装yum remove libpcapwget http://www.tcpdump.org/release/libpcap-1.4.0.tar.gztar zxvf libpcap-1.4.0.tar.gzcd libpcap-1.4.0./configuremakemake install解压编译和安装;tar zxvf intercept-1.0.0.tar.gzcd intercept-1.0.0./configure (默认raw socket方式抓包)make && make install最后运行 intercept;/usr/local/intercept/sbin/intercept -i eth1 -l intercept.log -P /var/run/intercept.pid -F 'tcp and src port 80' -d指令说明:-i 监控网卡接口-l 记录日志-F 监控的协议和端口-P 记录pid-d 以daemon形式运行其他参数可以通过/usr/local/intercept/sbin/intercept -h查看成功运行后可以观察到的网路连接状态:# ss -an |grep 36524LISTEN 0 5 *:36524 *:* ESTAB 0 66 192.168.0.219:36524 192.168.0.8:49034 ESTAB 0 0 192.168.0.219:36524 192.168.0.8:49035 ESTAB 0 66 192.168.0.219:36524 192.168.0.8:49032 ESTAB 0 0 192.168.0.219:36524 192.168.0.8:49033 第三步,在 test server 192.168.0.230上设置一条路由 :[root@bogon ~]# route add -net 10.10.10.0 netmask 255.255.255.0 gw 192.168.0.219成功运行测试时可以观察到的网络连接状态:# ss -an |headState Recv-Q Send-Q Local Address:Port Peer Address:PortLISTEN 0 0 127.0.0.1:199 *:* LISTEN 512 0 *:80 *:* ESTAB 0 0 192.168.0.230:80 10.10.10.1:62602ESTAB 0 0 192.168.0.230:80 10.10.10.4:54595ESTAB 0 0 192.168.0.230:80 10.10.10.3:53566ESTAB 0 0 192.168.0.230:80 10.10.10.6:49260ESTAB 0 0 192.168.0.230:80 10.10.10.8:57598ESTAB 0 0 192.168.0.230:80 10.10.10.7:64454ESTAB 0 0 192.168.0.230:80 10.10.10.1:63081
参考链接:http://blog.chinaunix.net/uid-25057421-id-5576741.html
收藏
举报
TAG: