docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > Docke资源限制

Docker容器实现资源限制的多种方式(如CPU和内存)

作者:思静鱼

在 Docker 中,可以通过设置容器运行参数,限制容器的 CPU、内存等资源使用量,从而防止某个容器占用过多资源,影响其他服务运行,本文给大家介绍了Docker容器实现资源限制的多种方式,需要的朋友可以参考下

一、内存限制(Memory)

限制最大内存使用:

docker run -m 512m --memory-swap 512m ubuntu
参数说明
-m 或 --memory设置最大可用物理内存(如 512m, 2g)
--memory-swap包含内存+交换分区(swap)的总限制
--memory-reservation软限制(仅在系统压力大时才强制限制)

推荐 --memory-swap 值与 --memory 相同,避免 swap 占用过多。

二、CPU 限制

Docker 默认不会限制 CPU,但你可以通过如下方式控制:

方法 1:限制可用 CPU 核心数

docker run --cpuset-cpus="0,1" ubuntu

表示容器只能使用第 0 和 1 核心。

方法 2:设置 CPU 份额(相对权重)

docker run --cpu-shares=512 ubuntu

方法 3:控制 CPU 使用比例

docker run --cpus="1.5" ubuntu

表示最多使用 1.5 核心(如果宿主机是多核,可跨核调度)。

三、综合示例(限制 CPU + 内存)

docker run -d \
  --name limited_container \
  -m 512m --memory-swap=512m \
  --cpus="1.0" \
  ubuntu sleep 1000

四、查看资源限制

docker inspect 容器ID

查看 JSON 中的 "HostConfig""Memory""NanoCpus" 等字段。

或使用命令:

docker stats 容器名

实时查看容器的 CPU、内存使用情况。

五、推荐实践

建议说明
限制生产容器的内存和 CPU防止容器 OOM、抢占系统资源
多容器部署时使用 --cpus精细控制资源分配
--memory-swap=memory 推荐设置一致避免 swap 被滥用
使用 Kubernetes 时通过资源 Request / Limit替代 Docker 参数方式
docker stats 做定期监控或报警配合 cadvisor / Prometheus

六、进阶控制(cgroups)

Docker 本质上是使用 Linux 的 cgroups 控制组 实现资源限制的,可以通过如下命令查看:

cat /sys/fs/cgroup/memory/docker/<container_id>/memory.limit_in_bytes

若你使用 containerd / podman 等容器引擎,也会采用类似方式控制资源。

七、总结图

docker run \
  --cpus="1.5" \
  --memory="1g" \
  --memory-swap="1g" \
  your-image

限制容器最大使用 1.5 核心、1GB 内存,不允许超额。

如你需要:

到此这篇关于Docker容器实现资源限制的多种方式(如CPU和内存)的文章就介绍到这了,更多相关Docke资源限制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文