memory cgroup起作用主要是限制各个进程使用内存大小,当其值超越限制值时会发生oom,讲当前进程清理掉。
memcg oom的主要运行流程如下:
首先进程在申请内存时会进行try_charge操作,此时会进行oom检测,如果是oom,则会把当前的memcg赋值给进程的memcg_in_oom成员,然后在缺页中断中会对当前进程是否存在oom进行判断,如果是,则发送oom events事件,然后清理进程。调用流程如下:
malloc->try_charge()->mem_cgroup_oom()------------------------>进程oom
handle_mm_fault()->mem_cgroup_oom_synchronize()->mem_cgroup_oom_notify()---------------->发送oom events
->mem_cgroup_out_of_memory()----------------->执行杀进程操作
在memory cgroup中有几个关键节点:
memory.memsw.limit_in_bytes//带上swap空间的最大值
memory.memsw.usage_in_bytes//当前带上swap的内存占用
memory.memsw.max_usage_in_bytes//历史使用的最大内存占用,包含swap空间占用
memory.soft_limit_in_bytes//当前内存使用的软限制
memory.limit_in_bytes//当前内存使用的硬限制
memory.max_usage_in_b