Re: [patch 0/4] mm: memcontrol: populate unified hierarchy interface

From: Michal Hocko
Date: Tue Aug 05 2014 - 08:40:39 EST


On Mon 04-08-14 17:14:53, Johannes Weiner wrote:
> Hi,
>
> the ongoing versioning of the cgroup user interface gives us a chance
> to clean up the memcg control interface and fix a lot of
> inconsistencies and ugliness that crept in over time.

The first patch doesn't fit into the series and should be posted
separately.

> This series adds a minimal set of control files to the new memcg
> interface to get basic memcg functionality going in unified hierarchy:

Hmm, I have posted RFC for new knobs quite some time ago and the
discussion died without some questions answered and now you are coming
with a new one. I cannot say I would be happy about that.

One of the concern was renaming knobs which represent the same
functionality as before. I have posted some concerns but haven't heard
back anything. This series doesn't give any rationale for renaming
either.
It is true we have a v2 but that doesn't necessarily mean we should put
everything upside down.

> - memory.current: a read-only file that shows current memory usage.

Even if we go with renaming existing knobs I really hate this name. The
old one was too long but this is not descriptive enough. Same applies to
max and high. I would expect at least limit in the name.

> - memory.high: a file that allows setting a high limit on the memory
> usage. This is an elastic limit, which is enforced via direct
> reclaim, so allocators are throttled once it's reached, but it can
> be exceeded and does not trigger OOM kills. This should be a much
> more suitable default upper boundary for the majority of use cases
> that are better off with some elasticity than with sudden OOM kills.

I also thought you wanted to have all the new limits in the single
series. My series is sitting idle until we finally come to conclusion
which is the first set of exposed knobs. So I do not understand why are
you coming with it right now.

> - memory.max: a file that allows setting a maximum limit on memory
> usage which is ultimately enforced by OOM killing tasks in the
> group. This is for setups that want strict isolation at the cost of
> task death above a certain point. However, even those can still
> combine the max limit with the high limit to approach OOM situations
> gracefully and with time to intervene.
>
> - memory.vmstat: vmstat-style per-memcg statistics. Very minimal for
> now (lru stats, allocations and frees, faults), but fixing
> fundamental issues of the old memory.stat file, including gross
> misnomers like pgpgin/pgpgout for pages charged/uncharged etc.

I am definitely for exposing LRU stats and have a half baked patch
sitting and waiting for some polishing. So I agree with the vmstat part.
Putting it into stat file is not the greatest match so a separate file
is good here.

> Documentation/cgroups/unified-hierarchy.txt | 18 +++
> include/linux/res_counter.h | 29 +++++
> include/linux/swap.h | 3 +-
> kernel/res_counter.c | 3 +
> mm/memcontrol.c | 177 +++++++++++++++++++++++++---
> mm/vmscan.c | 3 +-
> 6 files changed, 216 insertions(+), 17 deletions(-)
>

--
Michal Hocko
SUSE Labs
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/