限速之TC

来源:互联网 发布:网络记事本哪个好用 编辑:程序博客网 时间:2024/05/18 02:29
限速,关于限速,主要是限制服务器与客户端的之间的速度传输。
服务器与客户端的速度主要有两种:
第一个:服务器发信息给客户端,这时候,客户端会返回信息给服务器,主要是在服务器端ping值客户端的ip 
第二个,客户端发信息给服务器,这时候,服务器会返回信息给客户端,主要是在客户端ping值服务器
关于第一个,服务器没有必要获取到客户端返回的延迟的信息,但是我们需要模拟客户端获得服务器的延迟信息。所以,只需要在linux端限速就好。
使用linux限速的是自带的流量控制器:TC
首先介绍,网络发包会出现的情况
1、 延时:发送包的过程中,从客户端发送数据给服务器,服务器返回信息,有个时间的延时,不是发送包的同时就获得了服务器返回的包
2、 波动:每次发包都会有延时,但是延时的时间是不同的,会有包的延时,甚至延时过多了会出现包的丢失的情况
代码如下:
模拟延迟传输


 # tc  qdisc  add  dev  eth0  root  netem  delay  100ms  
该命令将 eth0 网卡的传输设置为延迟100毫秒发送。


更真实的情况下,延迟值不会这么精确,会有一定的波动,我们可以用下面的情况来模拟出带有波动性的延迟值:


 # tc  qdisc  add  dev  eth0  root  netem  delay  100ms  10ms
该命令将 eth0 网卡的传输设置为延迟 100ms ± 10ms (90 ~ 110 ms 之间的任意值)发送。


还可以更进一步加强这种波动的随机性:


 # tc  qdisc  add  dev  eth0  root  netem  delay  100ms  10ms  30%


该命令将 eth0 网卡的传输设置为 100ms ,同时,大约有30%的包会延迟 ± 10ms 发送。




模拟网络丢包:


 # tc  qdisc  add  dev  eth0  root  netem  loss  1%  


该命令将 eth0 网卡的传输设置为随机丢掉 1% 的数据包。
也可以设置丢包的成功率:


 # tc  qdisc  add  dev  eth0  root  netem  loss  1%  30%
该命令将 eth0 网卡的传输设置为随机丢掉 1% 的数据包,成功率为30% 。




模拟包重复:
 # tc  qdisc  add  dev  eth0  root  netem  duplicate 1% 
该命令将 eth0 网卡的传输设置为随机产生 1% 的重复数据包 。


 
模拟数据包损坏:
 # tc  qdisc  add  dev  eth0  root  netem  corrupt  0.2% 
该命令将 eth0 网卡的传输设置为随机产生 0.2% 的损坏的数据包 。 (内核版本需在2.6.16以上)


 


模拟数据包乱序:


 # tc  qdisc  change  dev  eth0  root  netem  delay  10ms   reorder  25%  50%


该命令将 eth0 网卡的传输设置为:有25%的数据包(50%相关)会被立即发送,其他的延迟10秒。


新版本中,如下命令也会在一定程度上打乱发包的次序:


 # tc  qdisc  add  dev  eth0  root  netem  delay  100ms  10ms


代码转自:http://sophia611.blog.163.com/blog/static/8544659720114610529960/ 亲自使用过,是正确的,很不错的工具,,楼主这几天在研究桥接、zip格式转换成rpm包以及linux的桥接问题,其实还想研究一下tcpdump等工具的实现原理,先记录着,希望以后能记得能歇歇文章,也能提高实战水平
0 0
原创粉丝点击