(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. 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 ? Other problem I'm not sure at all - blkcg doesn't support hierarchy at all. Hmm. Thanks, -Kame _______________________________________________ Containers mailing list Containers@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/containers