用 iptables 将网卡流量镜像到另一个主机

       最近在开发一个网络数据包的程序,平常测试的时候用tcpreplay 回放本地流量,或监听管理流量就可以,需要联调的时候就需要接入实时流量,一般是通过开启交换机的镜像口功能,将流量接入设备。

     我的测试环境是vmware vcenter 环境,产生数据是另外一个主机,数据的产生依赖于vm network,没办法构建独立的虚拟交换机,经过研究发现 iptables 的 tee 功能具有报文镜像功能。

TEE target options:
  --gateway IPADDR    Route packet via the gateway given by address
  --oif NAME          Include oif in route calculation

原理是复制一份报文,以网关的方式发送给目标主机,即修改目的MAC为目标主机转发过去,所以在同一个子网内,交换机可以将报文传送过去。

 命令如下:

iptables -t mangle -I PREROUTING 1   -j TEE --gateway 192.168.1.164
iptables -t mangle -I POSTROUTING 1  -j TEE --gateway 192.168.1.164 

通过抓包发现两个方向的报文的二层MAC地址都是一样的。

 

 

如果需要增加IP 或端口过滤,和普通命令一样。 我这里是数据库的业务,所以需要  PREROUTING 和 POSTROUTING 上分别增加规则,一条对本机收到报文,一条对发出的报文。

此方法可以解决需要镜像流量的问题,方便测试,从原理上看会影响一部分cpu和内存,不建议用到实际生产环境中。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值