Docker 实战:如何限制容器的内存使用大小

一、为什么要限制容器内存?

在使用 Docker 部署服务时,如果不加限制,某个容器可能因为内存泄漏或负载过高,导致主机内存被耗尽,拖垮其他容器甚至整个系统。

因此,在生产环境中,限制容器内存使用量(Memory Limit) 是一项关键的资源控制措施。


二、Docker 中的内存限制参数

Docker 基于 Linux 的 cgroups(控制组) 机制实现资源隔离。
和内存相关的主要参数如下:

参数 说明
--memory-m 限制容器最大可使用的物理内存
--memory-swap 限制容器可使用的总内存(物理内存 + swap)
--oom-kill-disable 是否禁用 OOM Killer(不建议在生产中关闭)

三、基础用法示例

1. 限制容器最大内存为 512MB

docker run -d --name myapp -m 512m nginx

此命令表示容器最多使用 512MB 内存。超过限制时,系统会触发 OOM 机制终止容器。


2. 同时限制内存与 swap

docker run -d --name myapp -m 512m --memory-swap 1g nginx

说明:

  • 物理内存上限:512MB
  • 总内存(含 swap)上限:1GB
  • 超出时系统自动使用 swap 空间

⚠️ 若 --memory-swap--memory 值相同,表示禁止使用 swap


四、查看容器的内存使用情况

使用以下命令可实时查看容器的资源使用:

docker stats

输出示例:

CONTAINER ID   NAME     MEM USAGE / LIMIT
a1b2c3d4e5f6   myapp    120.5MiB / 512MiB

也可通过以下命令查看详细配置:

docker inspect myapp | grep Memory






次阅读

扫描下方二维码,关注公众号:程序进阶之路,实时获取更多优质文章推送。


扫码关注

评论