Linuxtc命令限速实战教程
时间:2026-04-14 08:56:33 308浏览 收藏
本文深入解析Linux下使用tc命令进行网络限速的核心原理与实战要点,明确指出限速仅作用于本机出站流量且必须绑定物理网卡这一关键前提,系统对比tbf(适合整体硬限速)、htb+filter(支持按IP/端口精细分流)和wondershaper(便捷但功能受限的封装工具)三类方案的适用场景、典型命令、常见陷阱及排错技巧,并揭示限速生效的真实位置——协议栈出口至驱动前,帮助读者避开“配置正确却无效”的典型误区,真正掌握可控、可靠、可落地的网络带宽管理能力。

tc限速只对出站流量生效,且必须作用于真实网卡
这是最常被忽略的前提:无论你配得多精细,tc 的限速规则**只影响本机发出的数据(OUTPUT 方向)**,对进来的流量(如别人下载你的服务)完全无效。想限“下载速度”,得在对方机器上配;想限“上传速度”,才在你这配。
同时,tc 只能挂载到物理网卡(如 eth0、ens33),不能用在 lo、docker0 或 veth* 这类虚拟接口上——除非你明确在容器或命名空间里做透传,否则直接报错或静默失效。
- 先确认网卡名和状态:
ip link show,确保目标接口是UP - 检查是否已有规则:
tc qdisc show dev eth0,有输出就得先清掉,否则新规则不生效 - 所有命令必须带
sudo,普通用户权限不够
用 tbf 最简限速:适合整体出口带宽硬限制
tbf(Token Bucket Filter)是入门首选,原理简单、开销低、不依赖分类匹配,适合“把整个网卡发出去的流量压到 XX Mbps”这种场景。
比如把 eth0 出口压到 2Mbps:sudo tc qdisc add dev eth0 root tbf rate 2mbit burst 5kb latency 50ms
rate是平均速率,单位大小写敏感:mbit≠mbps,推荐统一用kbit/mbitburst太小(如1kb)会导致小包频繁丢弃,SSH 都可能卡顿;太大(如100kb)会让限速形同虚设;经验上设为rate / 10左右较稳latency不是延迟目标,而是允许排队等待的最大时长,设太小会激进丢包- 删规则只需:
sudo tc qdisc del dev eth0 root,不用记 classid 或 handle
按 IP 或端口限速:必须用 htb + filter 组合
想只限某台客户端(如 192.168.1.100)的上传,或只压 HTTP 流量(--dport 80),就不能单靠 tbf,得用分层结构:htb 定义带宽树,再用 u32 或 fw 过滤器把流量导进去。
常见错误是漏掉“根类”或搞错 parent 关系。正确链路是:root qdisc → 根 class → 子 class → filter 匹配 → flowid 导入。
- 必须先建根类(
classid 1:1),哪怕它只是总带宽占位符(如100mbit) - 子类的
classid必须带冒号,如1:10,不能写成110或10 - 过滤器要指定
protocol ip和parent 1:0(不是1:或1:1) - 若用
iptables打标(MARK),记得用fw类型 filter,并确保mangle表规则已加载
wondershaper 是什么?它不是万能胶,而是快速兜底工具
wondershaper 就是个封装了 tc + netem 的 shell 脚本,优势是快、少出错、自动处理上下行分离。但它不支持按 IP/端口精细分流,也不暴露底层 class 控制权。
装完直接跑:sudo wondershaper eth0 2048 512(下行 2048 Kbps,上行 512 Kbps)
- 它对上传限速靠
tbf,下载限速靠“入队丢包”,所以下载压得越狠,丢包率越高,TCP 重传越多 - 清除规则用
sudo wondershaper clear eth0,别用tc qdisc del混用,否则残留规则会冲突 - 如果你需要动态开关某 IP 的限速,或者做 QoS 优先级调度,
wondershaper就不够用了,得切回原生tc
真正容易被忽略的是:所有基于 tc 的限速,都只在数据包离开协议栈、进入驱动前生效。一旦网卡硬件队列已满,或者中断处理不过来,限速就失准了——这不是配置问题,是内核网络栈与硬件协同的天然边界。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
264 收藏
-
102 收藏
-
249 收藏
-
435 收藏
-
206 收藏
-
297 收藏
-
303 收藏
-
132 收藏
-
229 收藏
-
410 收藏
-
242 收藏
-
297 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习