限速,关于限速,主要是限制服务器与客户端的之间的速度传输。
服务器与客户端的速度主要有两种:
第一个:服务器发信息给客户端,这时候,客户端会返回信息给服务器,主要是在服务器端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等工具的实现原理,先记录着,希望以后能记得能歇歇文章,也能提高实战水平