您的位置:首页 >如何通过nohup命令限制后台进程的资源使用
发布于2026-04-27 阅读(0)
扫一扫,手机访问
很多朋友在用 nohup 命令把程序放到后台运行时,可能会遇到一个实际需求:能不能顺便给这个后台进程“上个笼头”,限制一下它的CPU或内存使用,别让它跑野了?
直接说结论:nohup 命令本身并不具备限制资源的功能,它只管“脱离终端、持续运行”这件事。但别急,我们可以借助其他工具组合实现这个目标,方法还挺灵活。

最直接的办法,是在启动进程前,通过 shell 内置的 ulimit 命令来设定资源天花板。这个命令能限制当前会话及其子进程的资源消耗。
举个例子,如果你想限制一个进程最多使用300秒CPU时间和512MB内存,可以这样操作:
ulimit -t 300 # 限制CPU时间为300秒
ulimit -v 512000 # 限制内存使用为512MB
nohup your_command &
这里有个关键点需要注意:ulimit 的设置是“会话级”的,只对当前shell及其启动的子进程有效。所以,如果你是在脚本里使用,务必把 ulimit 命令放在脚本开头、执行目标命令之前。否则,限制可能不会生效。
如果 ulimit 的全局限制不够精细,或者你需要更强大的隔离与控制能力,那么 Linux 内核的 cgroups(控制组)功能就是更专业的工具。它可以对进程组的资源进行限制、记录和隔离。
具体操作步骤稍微多几步,但逻辑很清晰:
sudo apt-get install cgroup-tools # 对于基于Debian的系统(如Ubuntu)
sudo yum install libcgroup-tools # 对于基于RHEL的系统(如CentOS)
sudo cgcreate -g cpu,memory:/my_cgroup
echo 300 | sudo tee /sys/fs/cgroup/cpu/my_cgroup/cpu.cfs_quota_us # 限制CPU时间为300秒
echo 512M | sudo tee /sys/fs/cgroup/memory/my_cgroup/memory.limit_in_bytes # 限制内存使用为512MB
这通常在启动进程后,通过其进程ID(PID)来操作。一个常见的做法是,在脚本中启动进程后,立即将其PID写入控制组的任务列表:
nohup your_command &
echo $! | sudo tee /sys/fs/cgroup/cpu/my_cgroup/tasks
echo $! | sudo tee /sys/fs/cgroup/memory/my_cgroup/tasks
这样一来,你的进程就会在刚才设定的CPU和内存限制下安稳运行了。当然,cgroups 的配置路径和参数可能因不同的Linux发行版或内核版本略有差异,实际操作时需要根据你的系统环境做微调。
总结一下,虽然 nohup 是个“甩手掌柜”,但配上 ulimit 或 cgroups 这两位“大管家”,就能轻松实现后台进程的资源管控。根据你对限制力度和精细度的要求,选择合适的方法即可。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9