关于docker:docker-内存-limit-与-swap-限制

4次阅读

共计 1228 个字符,预计需要花费 4 分钟才能阅读完成。

论断

主机层没有开启 swap,容器运行时无论怎么设置 –memory-swap,都不会应用到 swap,容器最大能应用的内存等于设置的内存限度;

主机层开启了 swap 如下表:

memory memory-swap 成果
M 负数 S 容器最大可用内存为 S,其中 ram 为 M,swap 为(S-M),若 S=M 则无可用 swap 资源
M 0 相当于未设置 memory-swap
M -1 容器最大可用内存为 M+ 主机可用 swap
M 未设置 容器最大可用内存为 2M,其中 ram 为 M,swap 为 M

<!– more –>

主机开启 swap

不设置 –memory-swap 参数

容器最大能够应用 2 倍的 –memory 内存 (可应用的 swap 大小跟内存限度的大小一样)

限度内存 100M,不设置 –memory-swap,容器申请应用 2X90M=180M,程序能够失常运行;docker stats 显示应用的内存量等于限度的内存量;查看 cgroup 里的 memory.stat 能够看到,swap 应用了大略 80M

限度内存 100M,不设置 –memory-swap,容器申请应用 2X150M=300M,因为最大容许应用内存 200M,容器启动失败;

设置 –memory-swap 100M

限度内存 100M,设置 –memory-swap=100M,容器申请应用 2X51M=102M,因为最大容许应用内存 100M,容器启动失败;

设置 –memory-swap -1

限度内存 100M,设置 –memory-swap=-1,容器申请应用 2X150M=300M,因为最大容许应用内存为 100M + 零碎 swap 大小,所以容器运行失常;docker stats 显示应用的内存量等于限度的内存量;查看 cgroup 里的 memory.stat 能够看到,swap 应用了大略 200M

限度内存 100M,设置 –memory-swap=-1,容器申请应用 2X200M=400M,因为最大容许应用内存为 100M + 零碎 swap 大小,所以容器运行失常;docker stats 显示应用的内存量等于限度的内存量;查看 cgroup 里的 memory.stat 能够看到,swap 应用了大略 300M

主机敞开 swap

不设置 –memory-swap 参数

限度内存 100M,未设置 –memory-swap(示意能够应用与内存限度一样的 swap),容器申请应用 2X51M=102M,因为最大容许应用内存 100M,主机没有 swap 可用,容器启动失败;

设置 –memory-swap 100M

限度内存 100M,设置 –memory-swap=200M,容器申请应用 2X51M=102M,因为最大容许应用内存 100M,主机没有 swap 可用,容器启动失败;

设置 –memory-swap -1

限度内存 100M,设置 –memory-swap=-1(示意应用主机的所有 swap),容器申请应用 2X51M=102M,因为最大容许应用内存 100M,主机没有 swap 可用,容器启动失败;

文章起源:李斯文的笔记本

正文完
 0