登录
首页 >  文章 >  linux

Linux流量控制工具全解析

时间:2025-12-01 11:34:26 491浏览 收藏

在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是文章学习者,那么本文《Linux限速技巧:流量控制工具详解》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!

Linux下限制带宽主要通过tc命令配合HTB实现,可结合iptables标记流量进行精细化控制;也可使用wondershaper简化操作,或用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学习网公众号也会发布文章相关知识,快来关注吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>