cgroup初步分析(1)

简介: cgroup的功能和作用不废话,直说一下cgroup的几条设计准则,有了几条设计准则的约束,就比较容易理解其中的数据结构和函数,至于源代码cgroup.c,无非是两个内容,一是task_struct、cgroup、css_set三个数据结构互相关联,而是cgroup文件系统的实现。
cgroup的功能和作用不废话,直说一下cgroup的几条设计准则,有了几条设计准则的约束,就比较容易理解其中的数据结构和函数,至于源代码cgroup.c,无非是两个内容,一是task_struct、cgroup、css_set三个数据结构互相关联,而是cgroup文件系统的实现。

先看设计准则:
  • 一个层级(hierarchy)就是一棵数,它可以包含一个资源子系统(subsys)或者多个资源子系统(subsys);

  • 一个资源子系统(subsys)只能存在一个层级(hierarchy);

  • 一个层级(hierarchy)中不同的cgroup之间的task都是互斥的,也就是说一个task只能存在于一个层级(hierarchy)中唯一的一个cgroup

  • 一个task可以同时存在于多个层级(hierarchy)中;即一个task对应于多个cgroup

  • 一个cgroup可以对应多个css_set

  • 一个css_set可以对应多个cgroup

  • 一个task只对应唯一一个css_set
问题1:如何通过一个 task找到它在某个层级( hierarchy)的 cgroup

下面的结构可以说明这种寻找关系:

方法1首先从task.cgroups找到css_set结构,从css_set结构中找到css_set结构对应的所有的cgroup,从中找出属于指定层hierarchycgroup每个层级都有一个唯一的top cgroup通过对比cgroup cgroup来判断是否属于该层级

方法2首先从task.cgroups找到css_set结构,从css_set结构struct cgroup_subsys_state *subsys[CGROUP_SUBSYS_COUNT]元素中找到每个子系统状态的结构struct cgroup_subsys_state变量其中有个指针,指向该子系统对应的cgroup

问题2:如何通过一个cgroup找到它目录下所有的task

cgroup通过cg_cgroup_link连接了多个css_set结构变量,每个结构变量都有一个tasks的链表,上面是该css_set对应的所有tasks。如图所示:




相关文章
|
11月前
|
Linux API C语言
cgroup V1和V2的原理和区别
cgroup V1和V2的原理和区别
|
Docker 容器
Cgroup 驱动
Cgroup 驱动
85 0
|
存储 缓存 Linux
blkio cgroup
blkio 是 cgroup v1 中的一个子系统,使用 cgroup v1 blkio 子系统主要是为了减少进程之间共同读写同一块磁盘时相互干扰的问题。
478 1
|
容器
pid cgroup
pid cgroup 简介
141 0
|
Shell 数据安全/隐私保护
使用cgroup对指定用户使用的memory进行限制的一个具体例子
使用cgroup对指定用户使用的memory进行限制的一个具体例子
145 0
使用cgroup对指定用户使用的memory进行限制的一个具体例子
cgroup
创建两个python进程,然后分别绑定在第0,1号CPU上.
cgroup