论断

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

主机层开启了 swap 如下表:

memorymemory-swap成果
M负数 S容器最大可用内存为S,其中 ram 为 M,swap 为(S-M),若 S=M 则无可用 swap 资源
M0相当于未设置 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 可用,容器启动失败;

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