为什么 Go pprof 和 Docker Stats 之间的“内存已用”指标不同
上下文
在运行的 Go 应用程序中Docker 容器中,docker stats 命令报告线性增加的内存使用情况。但是,使用 HTTP pprof 监视正在运行的应用程序时,runtime.MemStats.sys 值保持不变。这种差异引发了有关潜在内存泄漏的问题。
Cgroup 和内存指标
Docker stats 从 cgroup 中检索内存使用统计信息,从而优化内存访问以避免缓存线错误共享。因此,cgroups中的usage_in_bytes指标包括页面缓存和RES,它们占容器内的文件I/O。
内存回收
当容器的内存使用达到最大限制时,它会回收未使用的内存而不是终止进程。这解释了为什么 pprof 报告恒定的 runtime.MemStats.sys 值,而 docker stats 显示线性增加的内存使用量。
验证
要确认此行为,请添加使用 docker run 命令或 docker-compose.yml 文件对容器进行内存限制。观察到,当达到限制时,容器将回收内存并将其使用量保持在限制以下,如 /sys/fs/cgroup/memory/docker// 的 cgroups 中所示。
结论
pprof 和 docker stats 报告的内存使用情况的差异源于 docker stats 中包含文件 I/O 内存和内存当施加内存限制时,cgroup 采取的回收机制。通过了解这些因素,开发人员可以更准确地了解容器的内存消耗情况。
以上是为什么 Go pprof 和 Docker Stats 显示不同的内存使用指标?的详细内容。更多信息请关注PHP中文网其他相关文章!