登录
首页 >  文章 >  linux

Linux带宽限制方法及流量控制工具

时间:2026-05-20 13:10:44 215浏览 收藏

本文系统介绍了Linux环境下多种实用的带宽限制与流量控制方法:从底层灵活强大的tc命令配合HTB队列和iptables流量标记实现精细化系统级限速,到开箱即用的wondershaper简化日常带宽管控,再到无需root权限即可精准约束单个应用(如wget、Firefox)的trickle工具,同时还强调了iftop和nethogs等监控工具在识别高耗流进程、辅助策略制定中的关键作用——无论你是运维人员优化服务器网络资源,还是开发者调试应用带宽行为,或是普通用户管理家庭网络,都能从中找到适配场景、易于上手且真正有效的解决方案。

LINUX怎么限制带宽_LINUX网络流量控制工具

Linux下限制带宽主要通过网络流量控制工具实现,核心机制是利用内核的 tc(Traffic Control)命令配合 iptablesHTB(Hierarchical Token Bucket)等队列规则来管理数据包的发送速率。下面介绍几种常用方法和工具。

使用 tc 配合 HTB 限制接口带宽

tc 是 Linux 流量控制的核心工具,可用于设置出口带宽限制。例如,限制 eth0 接口的出站带宽为 1Mbps:

# 清除原有规则
tc qdisc del dev eth0 root 2> /dev/null
<h1>添加根队列,使用 HTB</h1><p>tc qdisc add dev eth0 root handle 1: htb default 30</p><h1>设置根类,总带宽 10mbit</h1><p>tc class add dev eth0 parent 1: classid 1:1 htb rate 10mbit</p><h1>创建子类,限制特定流为 1mbit</h1><p>tc class add dev eth0 parent 1:1 classid 1:10 htb rate 1mbit ceil 1mbit</p><h1>使用 iptables 打标记</h1><p>iptables -A OUTPUT -t mangle -p tcp --dport 80 -j CLASSIFY --set-class 1:10</p><h1>将匹配标记的数据流导向该类</h1><p>tc filter add dev eth0 protocol ip parent 1:0 prio 1 handle 10 fw classid 1:10</p>

上述命令将目标端口为 80 的 TCP 流量限制在 1Mbps。可以根据需要修改端口、IP 或协议进行更精细控制。

使用 wondershaper 简化操作

wondershaper 是一个封装了 tc 命令的脚本工具,适合快速上手。安装后可直接限制上下行带宽:

# 安装(以 Ubuntu 为例)
sudo apt install wondershaper
<h1>限制 eth0 接口:下行 2048 kbps,上行 512 kbps</h1><p>sudo wondershaper eth0 2048 512</p><h1>清除限制</h1><p>sudo wondershaper clear eth0</p>

适用于家庭网络或测试环境,配置简单但灵活性较低。

使用 trickle 控制单个应用程序带宽

trickle 是用户态带宽整形工具,无需 root 权限即可限制特定程序的上传下载速度。

# 安装
sudo apt install trickle
<h1>限制 wget 下载速度不超过 100KB/s</h1><p>trickle -d 100 wget <a target='_blank'  href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXpusdyfpJl5fdnHe6nQhNCyr5q5aZnDiZShxpCwnHynqajIprOifauEz757hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Jtt' rel='nofollow'>http://example.com/bigfile.zip</a></p><h1>限制上传和下载</h1><p>trickle -d 100 -u 50 firefox</p>

trickle 利用 LD_PRELOAD 劫持 socket 调用,因此仅支持动态链接的应用程序。

使用 nethogs 或 iftop 监控流量辅助调优

虽然不能直接限速,但 iftopnethogs 可帮助识别高带宽占用进程,便于制定限速策略:

# 查看实时接口流量
iftop -i eth0
<h1>按进程查看带宽使用</h1><p>nethogs eth0</p>

结合监控结果,再使用 tc 或 wondershaper 针对性地进行限制。

基本上就这些。根据场景选择合适工具:系统级限速用 tc + HTB,快速部署可用 wondershaper,应用级控制选 trickle。关键是理解流量方向(入口/出口)和分类规则。不复杂但容易忽略细节。

今天关于《Linux带宽限制方法及流量控制工具》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>