Chinaunix首页 | 论坛 | 博客
  • 博客访问: 645190
  • 博文数量: 175
  • 博客积分: 2457
  • 博客等级: 大尉
  • 技术积分: 1488
  • 用 户 组: 普通用户
  • 注册时间: 2011-07-13 20:31
文章分类

全部博文(175)

文章存档

2012年(22)

2011年(153)

分类: C/C++

2011-09-06 21:30:24

[linux] tc netem 模拟网络丢包


linux下的tc可以操纵网络,比如分配带宽给不同的应用、模拟网络时延、模拟糟糕网络环境下的丢包等。

      但在实际使用模拟丢包时,我们 发现了问题:两台服务器,一台跑tcp的server,一台跑tcp的client,client只send,server只recv(并打印出来),在 网络环境正常时,发送100万条消息只要40秒,但如果我们在两台服务器的任一台设上 " tc qdisc add dev eth0 root netem loss 1% " (在eth0设上1%的丢包率),消息的收发就戛然而止,strace发现时client阻塞在sendto上了(并没有发生我们送想象的“重传”机 制),把丢包率改回来(即恢复成正常网络),程序还是阻塞在sendto上。我们程序没写好?仔细检查,程序没问题(),而且我们发现,scp也会受同样的影响,表现和我们自己写的程序一样。难道tcp不可靠?

      结果发现时tc的用法不对。tc不是这样用的。中间需要用一个路由器。

      于是我们拿一台linux机当router,单网卡,两个虚拟ip,让它连接两台服务器再试。更滑稽了,tc不起作用,两台服务器间的流量刷刷的走,tc却显示没有多少packet经过。tc不能用于router吗?
后来看了(注意4.1节),终于知道了:tc标准用法是两台服务器中间一个双网卡的router,在router上用tc。

       最后测试成功。丢包率越高,tcp传输的速度越慢;如果丢包率很高,tcp可能会顿住,但是只要改回去(去掉tc的netem配置),传输就会恢复。
       TCP很可靠。



不知大家是否会做通信中间件相关的测试,比如说kfc或是自己实现的tcp通讯的测试,如果会涉及到,那么就有可能就需要对网络状态实现一些仿真,比如说模拟丢包,设置固定带宽等等;

这样的话,了解一下NETEM工具将是非常有用的,这是在之前KGB线上通信故障分析重现中用到的,和大家分享一下;NETEM可以做很多事情,比如说模拟丢包,重复发包,发乱序包等;简要说明如何使用:

step1:使用ifconfig命令查看你的网卡信息,如:eth0

step2:将网卡加入监控列表
sudo tc qdisc add dev eth0 root netem

step3:
设置丢包率
sudo tc qdisc change dev eth0 root netem loss 0.5%
设置重发
sudo tc qdisc change dev eth0 root netem duplicate 1%
设置发乱序包
sudo tc qdisc change dev eth0 root netem gap 5 delay 10ms

如果想让网络恢复正常,只需要将设置的值相应归0即可。
NetEM 包含在iproute2包中,由命令"tc"控制,使用起来很方便,不过需要说明一下:这个工具需要在Linux 2.6以上内核才包含。

NETEM还有很多其他的功能,以上只是一点皮毛,将NETEM的官方介绍提供出来,大家一些学习吧:

TC也是一个非常有用的工具,下面的链接是TC的介绍:

阅读(6913) | 评论(1) | 转发(1) |
给主人留下些什么吧!~~

饭饭小鱼儿2013-11-04 17:34:20

你好,我想通过fedora上的netemm作为路由器,服务器通过这个路由器发送数据包给客户端,应该怎么做呢?希望您能指点一下,帮助我更快的进步。