Linux下限速主要依靠tc工具,工作在内核出口方向,通过qdisc、class、filter三层结构实现;仅能限制本机发出流量,无法直接限制入向带宽。

Linux 下限速主要靠 tc(Traffic Control) 工具实现,它工作在内核网络栈的出口方向(即发包侧),通过队列规则(qdisc)、流量分类(class)和过滤匹配(filter)三层结构完成精细控制。限速本身不难,但需理解“控发不控收”的基本前提——tc 只能限制本机**发出**的流量,无法直接限制进入本机的下行带宽(入向需配合 ingress + police 或在上游设备配置)。
适合快速压测或全局限流场景,用最简的 TBF(Token Bucket Filter)队列:
tc qdisc add dev eth0 root tbf rate 500kbit burst 15kb latency 50ms
tc -s qdisc ls dev eth0(带 -s 可看实时统计)tc qdisc del dev eth0 root
TBF 简单可靠,适合单一流量整形;burst 和 latency 参数影响突发容忍度与排队延迟,调小 burst 可让限速更“硬”,但可能增加丢包。
使用 HTB(Hierarchical Token Bucket)支持分层带宽分配,再配合 u32 过滤器定向匹配:
tc qdisc add dev eth0 root handle 1: htb default 10
tc class add dev eth0 parent 1: classid 1:1 htb rate 10mbit
tc class add dev eth0 parent 1:1 classid 1:10 htb rate 2mbit ceil 3mbit
tc filter add dev eth0 protocol ip parent 1:0 prio 1 u32 match ip dst 192.168.1.100 flowid 1:10
注意:ceil 表示该类最大可用带宽(空闲时可突破 rate),default 10 指未匹配流量默认归入 1:10 类——若不想影响其他流量,建议设为一个宽松的兜底类。
关键在 u32 匹配条件中指定端口字段,适用于服务级 QoS:
tc filter add dev eth0 protocol ip parent 1:0 prio 2 u32 match ip dport 80 0xffff flowid 1:10
tc filter add dev eth0 protocol ip parent 1:0 prio 3 u32 match ip sport 7003 0xffff flowid 1:20
匹配语法中 0xffff 是掩码,表示精确匹配 16 位端口号;若要匹配 UDP,把 protocol ip 改为 protocol udp 即可。
netem 模块专为网络模拟设计,常用于测试弱网表现:
tc qdisc add dev eth0 root netem delay 100ms loss 5% rate 1mbit
tc qdisc add dev eth0 root netem delay 200ms
tc qdisc replace dev eth0 root netem ...
netem 必须作为 root qdisc 使用,不能嵌套在 HTB 下;如需组合使用,应将 netem 放在 HTB 子类的 leaf 队列中(需额外配置)。
以上就是Linux网络带宽如何限速_tc流量控制教程【教程】的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号