限速之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等工具的实现原理,先记录着,希望以后能记得能歇歇文章,也能提高实战水平
服务器与客户端的速度主要有两种:
第一个:服务器发信息给客户端,这时候,客户端会返回信息给服务器,主要是在服务器端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
- 限速之TC
- Linux TC 流量限速
- tc与限速实例
- TC限速例子
- tc 限速脚本实例
- linux tc 限速实例
- linux用tc限速
- Openwrt 限速—-tc iptalbe
- linux tc 对本机网卡限速
- 非常有用的TC限速例子
- linux下使用tc做流量限速
- 关于iptables和tc的限速理解
- 关于 iptables 和 tc 的限速理解
- 使用iptables和tc来进行限速
- 关于 iptables 和 tc 的限速理解
- ipp2p中使用tc+iptables限速(脚本)
- ipp2p中使用tc+iptables限速(脚本)
- Iptables+tc 网吧每IP 限速脚本
- C++结合LUA实现代码热更新
- C#开源
- 黑马程序员——网络编程及正则表达式
- nyoj118修路方案(次小生成树)
- C++ primer 第五版 中文版 练习 11.32 个人code
- 限速之TC
- java try catch finally
- linux cp 命令
- 数据结构java版一 预备知识
- poj 2069 Super Star
- redhat server 5.5 安装 git
- DELPHI判断同时按下CTRL+SHIFT组合键
- 利用 Ant 和 Eclipse 有效地提高部署工作效率
- RestTemplate的用法