如何在Linux中设置资源池 Linux cgroups用户限制

答案:通过cgroups机制为Linux用户devuser创建资源池,需先确认cgroup挂载,再创建cpu、memory控制组,设置CPU配额50%和内存限制2GB,最后通过systemd slice或手动方式将用户进程纳入控制组实现资源隔离与限制。

如何在Linux中设置资源池 Linux cgroups用户限制

在Linux中设置资源池并对用户进行资源限制,核心是通过Linux内核的Control Groups(cgroups)机制。这就像是给系统中的不同用户或进程分配独立的“资源预算”,确保一个用户或应用不会因为过度消耗CPU、内存或I/O等资源,而影响到整个系统的稳定性和其他用户的体验。简单来说,就是把资源“圈地”分配,避免“大锅饭”带来的性能波动。

解决方案

要在Linux中通过cgroups为用户设置资源限制,这并非简单地敲几行命令就能完成,更重要的是理解其背后的原理和层级关系。我个人觉得,理解这些比记住具体命令更重要。

首先,你需要确认你的Linux内核是否支持cgroups,并检查cgroup文件系统是否已经挂载。现代Linux发行版通常都默认开启并自动挂载了,你可以通过

mount | grep cgroup

来查看。如果未挂载,你需要手动创建目录并挂载,例如:

# 检查cgroup文件系统挂载情况 mount | grep cgroup  # 如果需要,手动挂载(通常由系统自动完成) # sudo mkdir -p /sys/fs/cgroup/cpu,memory,blkio # sudo mount -t cgroup -o cpu,memory,blkio none /sys/fs/cgroup/cpu,memory,blkio

这里我选择将

cpu

memory

blkio

(块设备I/O)这三个常用的子系统挂载到同一个层级,这在对用户进行综合资源限制时非常方便。

接下来,我们需要创建具体的控制组(cgroup)。假设我们想为用户

devuser

创建一个独立的资源池,限制其CPU和内存使用。我们会在每个子系统对应的层级下创建这个组:

# 为devuser在CPU子系统下创建控制组 sudo mkdir /sys/fs/cgroup/cpu/devuser_group  # 为devuser在Memory子系统下创建控制组 sudo mkdir /sys/fs/cgroup/memory/devuser_group

你会发现,对于每个你想要限制的资源类型(子系统),都需要创建对应的目录。这就像在不同的资源维度上,为

devuser

画出了一个专属的区域。

现在,我们可以设定具体的资源限制了。以CPU为例,我们使用

cpu.cfs_period_us

cpu.cfs_quota_us

来限制CPU带宽。

cfs_period_us

定义了一个调度周期(以微秒为单位),而

cfs_quota_us

则是在这个周期内,该cgroup被允许使用的CPU时间。比如,要限制

devuser_group

只能使用一个CPU核心的50%:

如何在Linux中设置资源池 Linux cgroups用户限制

Veggie AI

Veggie ai 是一款利用AI技术生成可控视频的在线工具

如何在Linux中设置资源池 Linux cgroups用户限制72

查看详情 如何在Linux中设置资源池 Linux cgroups用户限制

# 设置CPU周期为100毫秒 (100000微秒) sudo sh -c "echo 100000 > /sys/fs/cgroup/cpu/devuser_group/cpu.cfs_period_us" # 设置CPU配额为50毫秒 (50000微秒),即50%的CPU利用率 sudo sh -c "echo 50000 > /sys/fs/cgroup/cpu/devuser_group/cpu.cfs_quota_us"

内存限制则通过

memory.limit_in_bytes

文件来设定。例如,限制

devuser_group

最多使用2GB内存:

# 限制内存使用为2GB sudo sh -c "echo 2G > /sys/fs/cgroup/memory/devuser_group/memory.limit_in_bytes" # 你还可以设置软限制,当系统内存紧张时,会优先回收这部分内存 # sudo sh -c "echo 1.5G > /sys/fs/cgroup/memory/devuser_group/memory.soft_limit_in_bytes"

最后,也是最关键的一步,是将

devuser

的进程加入到这些控制组中。最直接的方法是找到

devuser

的进程ID(PID),然后将PID写入相应cgroup的

tasks

文件。

# 查找devuser的进程ID # ps -u devuser -o pid=  # 将PID写入CPU控制组的tasks文件 # sudo sh -c "echo <PID> > /sys/fs/cgroup/cpu/devuser_group/tasks" # 将PID写入内存控制组的tasks文件 # sudo sh -c "echo <PID> > /sys/fs/fs/cgroup/memory/devuser_group/tasks"

但这种手动方式显然不适合管理用户会话。更实际和推荐的方法是利用

systemd

的集成能力,或者使用

cgexec

命令。

对于

systemd

,我们可以创建一个

slice

单元文件来定义用户的资源限制。例如,创建一个

/etc/systemd/system/user-devuser.slice

文件:

[Unit] Description=Resource slice for devuser  [Slice] CPUQuota=50% MemoryLimit=2G

然后,加载并启用这个slice:

sudo systemctl enable user-devuser.slice sudo systemctl start user-devuser.slice

接着,你需要配置

devuser

的所有进程都运行在这个slice下。这通常涉及到修改PAM模块配置,或者利用

systemd-logind

的特性,让用户登录时其会话自动归

相关标签:

linux linux

上一篇
下一篇