在Ubuntu系统中,可以使用cgroups
(control groups)来限制进程的资源使用。cgroups
是Linux内核的一个功能,可以限制、记录和隔离进程组的资源使用(如CPU、内存、磁盘I/O等)。以下是如何使用cgroups
来限制进程资源使用的步骤:
cgroup-tools
软件包:sudo apt-get update
sudo apt-get install cgroup-tools
sudo cgcreate -g cpu,memory:/my_cgroup
这将创建一个名为my_cgroup
的新cgroup,限制CPU和内存资源。
echo 50000 | sudo tee /sys/fs/cgroup/cpu/my_cgroup/cpu.cfs_quota_us
这将限制my_cgroup
中的进程最多使用50%的CPU时间。
echo 100M | sudo tee /sys/fs/cgroup/memory/my_cgroup/memory.limit_in_bytes
这将限制my_cgroup
中的进程最多使用100MB的内存。
首先,找到要限制的进程的PID:
ps aux | grep your_process_name
然后,将进程添加到my_cgroup
:
sudo cgclassify -g cpu,memory:my_cgroup <PID>
将<PID>
替换为实际进程ID。
现在,my_cgroup
中的进程将受到之前设置的CPU和内存限制。
sudo cgdestroy -g cpu,memory:/my_cgroup
这将删除名为my_cgroup
的cgroup及其资源限制。
注意:在某些Ubuntu版本中,可能需要先启用cgroup v2。要启用cgroup v2,请按照以下步骤操作:
/etc/default/grub
文件:sudo nano /etc/default/grub
GRUB_CMDLINE_LINUX_DEFAULT
行中添加systemd.unified_cgroup_hierarchy=1
参数:GRUB_CMDLINE_LINUX_DEFAULT="quiet splash systemd.unified_cgroup_hierarchy=1"
保存文件并退出编辑器。
更新GRUB配置:
sudo update-grub
sudo reboot
现在,您的Ubuntu系统将使用cgroup v2。请注意,cgroup v2的命令和路径与cgroup v1略有不同。在上面的示例中,我们使用了适用于cgroup v2的路径(例如/sys/fs/cgroup/cpu/my_cgroup
)。