docker
stats显示cgroup的内存使用情况统计信息。(请参阅:https
:
//docs.docker.com/engine/admin/runmetrics/)
如果您阅读“过时但有用的”文档(https://www.kernel.org/doc/documentation/cgroup-v1/memory.txt),则会显示
5.5用法_in_bytes
为了提高效率,与其他内核组件一样,内存cgroup使用一些优化来避免不必要的缓存行错误共享。usage_in_bytes受此方法的影响,并且未显示内存(和交换)使用情况的“确切”值,它是有效访问的模糊值。(当然,在必要时,它是同步的。)如果您想知道更精确的内存使用情况,则应在memory.stat(请参阅5.2)中使用RSS
+ CACHE(+ SWAP)值。
页面缓存和RES包含在内存usage_in_bytes编号中。因此,如果容器具有文件I /
O,则内存使用情况统计将增加。但是,对于一个容器,如果使用量达到该最大限制,它将回收一些未使用的内存。因此,当我向容器添加内存限制时,我可以观察到达到该限制时会回收并使用内存。除非没有要回收的内存并且发生OOM错误,否则不会终止容器进程。对于任何关心docker
stats中显示的数字的人,简单的方法是在以下位置检查cgroups中可用的详细统计信息:/ sys / fs / cgroup / memory /
docker //这将详细显示内存中的所有内存指标。统计信息或其他memory。*文件。
如果要在“ docker
run”命令中限制docker容器使用的资源,可以通过参考以下内容进行限制:https
:
//docs.docker.com/engine/admin/resource_constraints/
由于我使用的是docker-compose,因此我在docker-compose.yml文件中要限制的服务下添加了一行:
mem_limit:32m
其中m代表兆字节。



