From: Srivatsa Vaddagiri <vatsa@linux.vnet.ibm.com>
To: linux-kernel@vger.kernel.org
Cc: a.p.zijlstra@chello.nl, Ingo Molnar <mingo@elte.hu>,
menage@google.com, containers@lists.osdl.org,
dhaval@linux.vnet.ibm.com, Balbir Singh <balbir@in.ibm.com>,
pj@sgi.com
Subject: [RFC] Default child of a cgroup
Date: Thu, 31 Jan 2008 08:10:49 +0530 [thread overview]
Message-ID: <20080131024049.GA9544@linux.vnet.ibm.com> (raw)
Hi,
As we were implementing multiple-hierarchy support for CPU
controller, we hit some oddities in its implementation, partly related
to current cgroups implementation. Peter and I have been debating on the
exact solution and I thought of bringing that discussion to lkml.
Consider the cgroup filesystem structure for managing cpu resource.
# mount -t cgroup -ocpu,cpuacct none /cgroup
# mkdir /cgroup/A
# mkdir /cgroup/B
# mkdir /cgroup/A/a1
will result in:
/cgroup
|------<tasks>
|------<cpuacct.usage>
|------<cpu.shares>
|
|----[A]
| |----<tasks>
| |----<cpuacct.usage>
| |----<cpu.shares>
| |
| |---[a1]
| |----<tasks>
| |----<cpuacct.usage>
| |----<cpu.shares>
| |
|
|----[B]
| |----<tasks>
| |----<cpuacct.usage>
| |----<cpu.shares>
|
Here are some questions that arise in this picture:
1. What is the relationship of the task-group in A/tasks with the
task-group in A/a1/tasks? In otherwords do they form siblings
of the same parent A?
2. Somewhat related to the above question, how much resource should the
task-group A/a1/tasks get in relation to A/tasks? Is it 1/2 of parent
A's share or 1/(1 + N) of parent A's share (where N = number of tasks
in A/tasks)?
3. What should A/cpuacct.usage reflect? CPU usage of A/tasks? Or CPU usage
of all siblings put together? It can reflect only one, in which case
user has to manually derive the other component of the statistics.
It seems to me that tasks in A/tasks form what can be called the
"default" child group of A, in which case:
4. Modifications to A/cpu.shares should affect the parent or its default
child group (A/tasks)?
To avoid these ambiguities, it may be good if cgroup create this
"default child group" automatically whenever a cgroup is created?
Something like below (not the absence of tasks file in some directories
now):
/cgroup
|
|------<cpuacct.usage>
|------<cpu.shares>
|
|---[def_child]
| |----<tasks>
| |----<cpuacct.usage>
| |----<cpu.shares>
| |
|
|----[A]
| |
| |----<cpuacct.usage>
| |----<cpu.shares>
| |
| |---[def_child]
| | |----<tasks>
| | |----<cpuacct.usage>
| | |----<cpu.shares>
| | |
| |
| |---[a1]
| |
| |----<cpuacct.usage>
| |----<cpu.shares>
| |
| |---[def_child]
| | |---<tasks>
| | |---<cpuacct.usage>
| | |---<cpu.shares>
| | |
|
|----[B]
| |
| |----<cpuacct.usage>
| |----<cpu.shares>
| |
| |---[def_child]
| | |----<tasks>
| | |----<cpuacct.usage>
| | |----<cpu.shares>
| | |
Note that user cannot create subdirectories under def_child with this
scheme! I am also not sure what impact this will have on other resources
like cpusets ..
Thoughts?
--
Regards,
vatsa
next reply other threads:[~2008-01-31 2:29 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-01-31 2:40 Srivatsa Vaddagiri [this message]
2008-01-31 17:44 ` [RFC] Default child of a cgroup Serge E. Hallyn
2008-01-31 18:09 ` Balbir Singh
2008-01-31 20:37 ` Peter Zijlstra
2008-02-01 4:16 ` Dhaval Giani
2008-02-01 3:53 ` Dhaval Giani
2008-01-31 21:13 ` Vivek Goyal
2008-02-01 2:39 ` Paul Menage
2008-02-01 3:32 ` Balbir Singh
2008-02-01 3:40 ` Dhaval Giani
2008-02-01 7:58 ` Peter Zijlstra
2008-02-01 15:35 ` Paul Menage
2008-02-01 8:19 ` Srivatsa Vaddagiri
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20080131024049.GA9544@linux.vnet.ibm.com \
--to=vatsa@linux.vnet.ibm.com \
--cc=a.p.zijlstra@chello.nl \
--cc=balbir@in.ibm.com \
--cc=containers@lists.osdl.org \
--cc=dhaval@linux.vnet.ibm.com \
--cc=linux-kernel@vger.kernel.org \
--cc=menage@google.com \
--cc=mingo@elte.hu \
--cc=pj@sgi.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox