商城首页欢迎来到中国正版软件门户

您的位置:首页 >如何通过nohup命令限制后台进程的资源使用

如何通过nohup命令限制后台进程的资源使用

  发布于2026-04-27 阅读(0)

扫一扫,手机访问

如何通过nohup命令限制后台进程的资源使用

很多朋友在用 nohup 命令把程序放到后台运行时,可能会遇到一个实际需求:能不能顺便给这个后台进程“上个笼头”,限制一下它的CPU或内存使用,别让它跑野了?

直接说结论:nohup 命令本身并不具备限制资源的功能,它只管“脱离终端、持续运行”这件事。但别急,我们可以借助其他工具组合实现这个目标,方法还挺灵活。

如何通过nohup命令限制后台进程的资源使用

方法一:使用 ulimit 命令设置资源上限

最直接的办法,是在启动进程前,通过 shell 内置的 ulimit 命令来设定资源天花板。这个命令能限制当前会话及其子进程的资源消耗。

举个例子,如果你想限制一个进程最多使用300秒CPU时间和512MB内存,可以这样操作:

ulimit -t 300      # 限制CPU时间为300秒
ulimit -v 512000   # 限制内存使用为512MB
nohup your_command &

这里有个关键点需要注意:ulimit 的设置是“会话级”的,只对当前shell及其启动的子进程有效。所以,如果你是在脚本里使用,务必把 ulimit 命令放在脚本开头、执行目标命令之前。否则,限制可能不会生效。

方法二:借助 cgroups 进行精细管控

如果 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 是个“甩手掌柜”,但配上 ulimitcgroups 这两位“大管家”,就能轻松实现后台进程的资源管控。根据你对限制力度和精细度的要求,选择合适的方法即可。

本文转载于:https://www.yisu.com/ask/38754832.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注