如何用ulimit控制网络带宽
如何用ulimit控制网络带宽?你可能想错了方向
提到系统资源限制,很多朋友的第一反应就是 ulimit 命令。没错,它在管理用户进程资源方面确实是个好手,比如控制文件描述符数量、进程数上限这些。但如果你想把限制网络带宽的希望寄托在它身上,那恐怕要失望了——ulimit 本身并不提供直接限制网络带宽的功能。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

那么,真正要管住网络的“水管”,该用什么工具呢?别急,下面就来聊聊两个更专业的选手:tc(Traffic Control)和 nftables。
使用 tc 限制网络带宽
tc 是 Linux 内核自带的功能强大的流量控制工具,可以说是精细化管理带宽的“瑞士军刀”。具体怎么用?我们一步步来看。
- 准备工作:首先,确保你的系统已经安装了
iproute2软件包,它包含了tc命令。安装命令很简单:
sudo apt-get install iproute2 # Debian/Ubuntu
sudo yum install iproute # CentOS/RHEL
- 设置全局带宽限制:接下来,使用
tc命令创建一个队列规则(qdisc)来给网络接口“套上缰绳”。比如,想把网卡eth0的上传和下载速度都限制在 1Mbps,可以执行以下命令:
sudo tc qdisc add dev eth0 root handle 1: htb default 30
sudo tc class add dev eth0 parent 1: classid 1:1 htb rate 1mbit
sudo tc class add dev eth0 parent 1:1 classid 1:30 htb rate 1mbit
- (进阶)限制特定进程:如果不想“一刀切”,只想限制某个特定程序的带宽,
tc也能做到。这就需要用到它的u32过滤器了。先找到目标进程的 PID 和它使用的端口,然后创建一个过滤器:
sudo tc filter add dev eth0 protocol ip parent 1:0 prio 1 u32 match ip sport <进程端口> flowid 1:30
记得把 <进程端口> 替换成实际的端口号。这样一来,只有通过这个端口的流量才会被限制速度。
使用 nftables 限制网络带宽
除了 tc,新一代的防火墙工具 nftables 也提供了灵活的带宽限制能力,配置起来更像是在写一份策略声明。
- 安装工具:首先,确保系统里已经安装了
nftables:
sudo apt-get install nftables # Debian/Ubuntu
sudo yum install nftables # CentOS/RHEL
- 编写规则集:创建一个规则文件,比如叫
bandwidth.nft,然后把下面的策略写进去:
#!/usr/sbin/nft -f
flush ruleset
table ip filter {
chain input {
type filter hook input priority 0; policy drop;
# 允许本地回环接口的流量
iif lo accept
# 允许已建立的连接
ct state established,related accept
# 限制带宽:超过1Mbps的部分将被丢弃
limit rate over 1mbit burst 10kb burst 10kb accept
# 拒绝其他所有流量
drop
}
chain forward {
type filter hook forward priority 0; policy drop;
# 允许本地回环接口的流量
iif lo accept
# 允许已建立的连接
ct state established,related accept
# 限制带宽
limit rate over 1mbit burst 10kb burst 10kb accept
# 拒绝其他所有流量
drop
}
chain output {
type filter hook output priority 0; policy accept;
}
}
其中,over 1mbit 这个参数就是关键,把它改成你想要的带宽上限即可。
- 加载并启用规则:写好之后,用一条命令加载它:
sudo nft -f bandwidth.nft
- 设置开机自启:如果希望重启后规则依然生效,记得把上面的加载命令添加到
/etc/rc.local文件里(放在exit 0这行之前)。
最后必须提醒一句:无论是 tc 还是 nftables,它们对网络流量的干预都是直接而有力的。在生产环境应用之前,务必在测试环境中充分验证,避免因为配置不当影响关键的网络服务。毕竟,把水管拧得太紧,谁都喝不上水了。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
centos php配置如何生效
在 CentOS 系统中,如何让 PHP 配置修改真正生效? 在 CentOS 系统里折腾 PHP 配置,有个关键步骤常常被忽略:修改完配置文件,只是完成了第一步。想让改动真正发挥作用,你得重启对应的服务才行。这道理其实很简单,就好比你给电脑换了张壁纸,不刷新一下桌面,看到的还是老样子。 下面,我们
php在centos上如何启动
在CentOS上启动PHP:从安装到验证的完整指南 想在CentOS系统上顺利启动PHP吗?这事儿其实不难,但得按部就班来。核心在于确保PHP和Web服务器(比如Apache或Nginx)都已就位,并且正确配置。下面这份手把手的流程,能帮你快速搞定。 第一步:安装PHP 首先,你得确认系统里已经装好
centos php配置文件怎么编辑
CentOS 上 PHP 配置文件的编辑指南 在 CentOS 系统上调整 PHP 配置,是服务器运维和 Web 应用部署中的一项常规操作。整个过程其实并不复杂,关键在于找准配置文件的位置,并遵循正确的编辑与生效流程。下面,我们就来一步步拆解。 第一步:打开终端 所有操作都从终端开始。无论是通过 S
centos如何修改php配置
在CentOS上修改PHP配置的完整指南 调整PHP配置是服务器管理中的一项常见操作。今天,我们就来详细拆解一下在CentOS系统上修改PHP配置的完整流程。整个过程逻辑清晰,只要按步骤操作,通常都能顺利完成。 第一步:打开终端 所有操作都将从终端开始。确保你拥有足够的权限,通常意味着你需要使用su
centos下php如何优化配置
在CentOS系统下优化PHP配置 想让你的PHP应用在CentOS上跑得更快、更稳、更安全吗?秘诀往往就藏在那个关键的配置文件——php ini里。通过调整其中的一些核心参数,你就能显著提升性能并加固安全防线。下面,我们就来逐一拆解那些最值得关注的优化项。 1 调整内存限制 首先,打开php i
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

