微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

限制linux中的传入和传出带宽和延迟

我发现很多类似的问题已经被问到,但到目前为止我还没有找到解决问题的方法.

我有一个虚拟的Linux服务器(运行Debian Squeeze),我用它来测试网站速度,以衡量所述网站的加载时间的增加和减少.我试图限制此服务器的带宽和延迟,以便能够接近网站上的实际加载时间,但迄今为止失败了.

我特别想要的是以下内容

>设置50 ms的传入和传出延迟.
>设置512 kbps的传入带宽限制.
>设置传出带宽限制为4096 kbps.

我一直在阅读netem和使用tc命令,但它仍然有点过头了.我已经设法将这个命令放在一起来控制似乎有效的延迟,但我甚至不确定它是否只处理传出延迟或两者:

tc qdisc add dev eth0 root netem delay 50ms

周围的网络专家可以帮助我吗?

编辑:

经过进一步研究后,我已达到目标的一半,使用此命令,所有传出流量的行为都符合我的要求:

tc qdisc add dev eth0 root tbf rate 4.0mbit latency 50ms burst 50kb mtu 10000

但是,我仍然无法正确限制传入流量.我已经知道我应该使用“Ingress Policer过滤器”我一直试图用下面的命令做到这一点,玩弄不同的值,但没有运气.

tc qdisc add dev eth0 ingress
tc filter add dev eth0 parent ffff: protocol ip u32 match ip src 0.0.0.0/0 flowid :1 police rate 1.0mbit mtu 10000 burst 10k drop

然而,带宽受命令影响,上面的值使速度从2MB / s开始,并且随着传输的进行,缓慢下降到大约80-90kB / s,它在传输大约30秒后到达.

关于我做错的任何想法?

解决方法

我最终决定只在服务器上设置传出带宽/延迟,然后在客户端上做同样的事情,有效地达到相同的结果.

这些是我分别在服务器和客户端上运行的命令,以实现我的目标:

服务器:4 Mbit 50 ms

tc qdisc add dev eth0 handle 1: root htb default 11
tc class add dev eth0 parent 1: classid 1:1 htb rate 1000Mbps
tc class add dev eth0 parent 1:1 classid 1:11 htb rate 4Mbit
tc qdisc add dev eth0 parent 1:11 handle 10: netem delay 50ms

客户端:512 kbit 50 ms

tc qdisc add dev vmnet1 handle 1: root htb default 11
tc class add dev vmnet1 parent 1: classid 1:1 htb rate 1000Mbps
tc class add dev vmnet1 parent 1:1 classid 1:11 htb rate 512kbit
tc qdisc add dev vmnet1 parent 1:11 handle 10: netem delay 50ms

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐