简介
Cgroups是
control groups
的缩写,是
Linux
内核提供的一种可以限制、记录、隔离进程组(
process groups
)所使用的物理资源(如:
cpu,memory,IO
等等)的机制。最初由
google
的工程师提出,后来被整合进
Linux
内核。
环境
Ubuntu 16.04 LTS
Cgroup 安装
% apt install cgroup-bin cgroup-tools cgroup-lite
相关术语
任务(task),控制族群(control group),层级(hierarchy),子系统(subsytem)
可在 /sys/fs/cgroup/目录下查看已经挂载的子系统
使用方法
控制 cpu
% cd /sys/fs/cgroup/cpu
% mkdir test && cd test # 新建 控制族群,其中自动会生成一系列文件
% echo 50000 > cpu.cfs_quota_us # 设置 cpu 使用率为50% (将 cpu.cfs_quota_us 中的值除以 cpu.cfs_period_us 中的值)
% echo 12345 > tasks # 将进程id写入tasks
% cd .. && rmdir test # 删除 控制族群
可以发现进程cpu使用率不会超过50%
控制 内存
% cd /sys/fs/cgroup/memory
% mkdir test && cd test # 新建 控制族群,其中自动会生成一系列文件
% echo 1M > memory.limit_in_bytes # 设置内存使用上限是 1M
% echo 12345 > tasks # 将进程id写入tasks
% cd .. && rmdir test # 删除 控制族群当进程内存使用超过1M时,会触发OOM( out of memory ),进程会被 kill 掉
注意
当某个进程加入了某个控制族群,它之后产生的子进程也会自动加入
% echo $$
28259
% echo $$ > tasks
% cat tasks
28259
28304进程 28304 是 cat 进程
本文介绍了Cgroups(Control Groups)的概念及其在Linux系统中的应用。Cgroups能够限制、记录和隔离进程组使用的物理资源,例如CPU、内存和I/O等。文章通过具体实例展示了如何使用Cgroups来控制CPU和内存资源。
2610

被折叠的 条评论
为什么被折叠?



