我有一个
linux盒子(Centos 5.5),我想在其上限制网络流量.我有一个应用程序,我们分发给客户端,我想在256Mbit /秒的最小建议带宽上进行测试.到目前为止,我看到的tc教程似乎允许你根据某些标准限制带宽,但我想限制所有情况下的带宽(往/返所有IP地址,无论IP头是什么样的,等等).
一个教程建议我使用:
tc filter add dev eth0 protocol ip parent 10: prio 2 flowid 10:2
但是我收到以下错误:
Unknown filter "flowid",hence option 10:2 is unparsable
关于如何在所有情况下限制进出eth0的带宽的任何想法?
解决方法
如果要对所有出站流量应用限制,则根本不需要过滤器.只需将您的qdisc添加到接口根句柄,如下所示:
tc qdisc add dev eth0 root handle 1: tbf rate 256mbit latency 1ms burst 1540
如果你想塑造/警告入站流量,那就有点复杂了.你需要使用例如一个IFB接口:
modprobe ifb ip link set dev ifb0 up tc qdisc add dev eth0 ingress tc filter add dev eth0 parent ffff: protocol ip u32 match u32 0 0 action mirred egress redirect dev ifb0 # ^- this is a dummy filter,match u32 0 0 matches all traffic tc qdisc add dev ifb0 root handle 1: tbf rate 256mbit latency 1ms burst 1540
这是一种不同的方法,使用两个简单的过滤器:
tc qdisc add dev eth0 ingress tc filter add dev eth0 root protocol ip u32 match u32 0 0 police rate 256mbit burst 10k drop flowid :1 tc filter add dev eth0 parent ffff: protocol ip u32 match u32 0 0 police rate 256mbit burst 10k drop flowid :1
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。