tcpcopy的使用

tcpcopy 两台虚拟机不行,因为外网的ip是经过转发的
保证网络整洁才能进行测试

在本地用两台虚拟机
10.230.13.237
10.230.13.140

目的:
假设10.230.13.140是线上机器
想吧140接受到的请求都复制一份转发到237上进行测试


具体操作
两台都装上nginx 并启动,假设都使用的80端口
都装上tcpcopy
使用的是tcpcopy-0.9.6.tar.gz ( http://dl.iteye.com/topics/download/54e38ce7-7afe-3e36-a433-87e32c283b38)
安装
./configure --prefix=/usr/local/tcpcopy
make
make install

目前想让140机器的所有80端口请求复制一份到237上
操作如下
---------------------------------------

在237上操作:
tail -f /usr/local/nginx_upstream/logs/access.log
观察日志写入


清空iptables
iptables --list
iptables -F


建立网络
modprobe ip_queue
iptables -I OUTPUT -p tcp --sport 80 -j QUEUE
/usr/local/tcpcopy/bin/intercept &

237已经准备好接受请求
-------------------------------
在另一台机器140上操作:
/usr/local/tcpcopy/bin/tcpcopy -x 80-10.230.13.237:80 &

表示把本机的80端口的请求都copy一份到10.230.13.237的80端口
规则是
tcpcopy -x <本机端口>-<从本机复制到的目标机器的ip>:<目标机器的端口>

接下来访问140就回在237上收到访问日志
注意观察刚才237上的access.log

然后在140上或其他机器触发
curl 10.230.13.140

在237上会得到相同的来自140的请求


或者在237上使用
tcpdump -n -i eth0 -s 0 -w output.txt src or dst port 80 

然后tailf output.txt

在触发140后,237也会有结果产生

你可能感兴趣的:(tcpcopy)