On 06/01/2017 02:47 PM, Tejun Heo wrote: > Hello, Waiman. > > On Thu, Jun 01, 2017 at 02:44:48PM -0400, Waiman Long wrote: >>> And cgroup-v2 has this 'exception' (aka wart) for the root group which >>> needs to be replicated for each namespace. >> One of the changes that I proposed in my patches was to get rid of the >> no internal process constraint. I think that will solve a big part of >> the container invariant problem that we have with cgroup v2. > I'm not sure. It just masks it without actually solving it. I mean, > the constraint is thereq for a reason. "Solving" it would defeat one > of the main capabilities for resource domains and masking it from > kernel side doesn't make whole lot of sense to me given that it's > something which can be easily done from userland. If we take out that > part, for controllers which don't care about resource domains, > wouldn't thread mode be a sufficient solution? As said in an earlier email, I agreed that masking it on the kernel side may not be the best solution. I offer 2 other alternatives: 1) Document on how to work around the resource domains issue by proper setup of the cgroup hierarchy. 2) Mark those controllers that require the no internal process competition constraint and disallow internal process only when those controllers are active. I prefer the first alternative, but I can go with the second if necessary. The major rationale behind my enhanced thread mode patch was to allow something like R -- A -- B \ T1 -- T2 where you can have resource domain controllers enabled in the thread root as well as some child cgroups of the thread root. As no internal process rule is currently not applicable to the thread root, this creates the dilemma that we need to deal with internal process competition. The container invariant that PeterZ talked about will also be a serious issue here as I don't think we are going to set up a container root cgroup that will have no process allowed in it because it has some child cgroups. IMHO, I don't think cgroup v2 will get wide adoption without getting rid of that no internal process constraint. Cheers, Longman -- To unsubscribe from this list: send the line "unsubscribe cgroups" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html