论断
主机层没有开启 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 可用,容器启动失败;
文章起源:李斯文的笔记本