(2012/03/14 18:46), Glauber Costa wrote:
On 03/14/2012 04:28 AM, KAMEZAWA Hiroyuki wrote:IIUC, in general, even in the processes are in a tree, in major case
of servers, their workloads are independent.
I think FLAT mode is the dafault. 'heararchical' is a crazy thing which
cannot be managed.
Better pay attention to the current overall cgroups discussions being
held by Tejun then. ([RFD] cgroup: about multiple hierarchies)
The topic of whether of adapting all cgroups to be hierarchical by
deafult is a recurring one.
I personally think that it is not unachievable to make res_counters
cheaper, therefore making this less of a problem.
I thought of this a little yesterday. Current my idea is applying following
rule for res_counter.
1. All res_counter is hierarchical. But behavior should be optimized.
2. If parent res_counter has UNLIMITED limit, 'usage' will not be propagated
to its parent at _charge_.
3. If a res_counter has UNLIMITED limit, at reading usage, it must visit
all children and returns a sum of them.
Then,
/cgroup/
memory/ (unlimited)
libivirt/ (unlimited)
qeumu/ (unlimited)
guest/(limited)
All dir can show hierarchical usage and the guest will not have
any lock contention at runtime.
Well, increasing the limit should be always possible.
By this
1. no runtime overhead if the parent has unlimited limit.
2. All res_counter can show aggregate resource usage of children.
To do this
1. res_coutner should have children list by itself.
Implementation problem
- What should happens when a user set new limit to a res_counter which have
childrens ? Shouldn't we allow it ? Or take all locks of children and
update in atomic ?
- memory.use_hierarchy should be obsolete ?If we're going fully hierarchical, yes.