Hi Johannes, On Thu, Jan 14, 2016 at 03:24:08PM -0500, Johannes Weiner wrote: ... > The output of this file looks as follows: > > $ cat memory.stat > anon 167936 > file 87302144 > file_mapped 0 > file_dirty 0 > file_writeback 0 > inactive_anon 0 > active_anon 155648 > inactive_file 87298048 > active_file 4096 > unevictable 0 > pgfault 636 > pgmajfault 0 > > The list consists of two sections: statistics reflecting the current > state of the memory management subsystem, and statistics reflecting > past events. The items themselves are sorted such that generic big > picture items come before specific details, and items related to > userspace activity come before items related to kernel heuristics. > > All memory counters are in bytes to eliminate all ambiguity with > variable page sizes. > > There will be more items and statistics added in the future, but this > is a good initial set to get a minimum of insight into how a cgroup is > using memory, and the items chosen for now are likely to remain valid > even with significant changes to the memory management implementation. > > Signed-off-by: Johannes Weiner <hannes@xxxxxxxxxxx> With the follow-up it looks good to me. All exported counters look justified enough and the format follows that of other cgroup2 controllers (cpu, blkio). Thanks! Acked-by: Vladimir Davydov <vdavydov@xxxxxxxxxxxxx> One addition though. May be, we could add 'total' field which would show memory.current? Yeah, this would result in a little redundancy, but I think that from userspace pov it's much more convenient to read the only file and get all stat counters than having them spread throughout several files. Come to think of it, do we really need separate memory.events file? Can't these counters live in memory.stat either? Yeah, this file generates events, but IMHO it's not very useful the way it is currently implemented: Suppose, a user wants to receive notifications about OOM or LOW events, which are rather rare normally and might require immediate action. The only way to do that is to listen to memory.events, but this file can generate tons of MAX/HIGH when the cgroup is performing normally. The userspace app will have to wake up every time the cgroup performs reclaim and check memory.events just to ensure no OOM happened and this all will result in wasting cpu time. May be, we could generate LOW/HIGH/MAX events on memory.low/high/max? This would look natural IMO. Don't know where OOM events should go in this case though. Thanks, Vladimir -- 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