Docker 容器如何实现资源限制(如 CPU 和内存)

在 Docker 中,可以通过设置容器运行参数,限制容器的 CPU、内存等资源使用量,从而防止某个容器占用过多资源,影响其他服务运行。


一、内存限制(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
  • 默认是 1024
  • 多个容器分配 CPU 份额:容器 A 是 512,容器 B 是 1024,B 获取 CPU 的概率是 A 的 2 倍

方法 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
  • 限制最大 512MB 内存
  • 限制最多 1 个 CPU 核心

四、查看资源限制

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-compose.yml 中配置资源限制
  • Kubernetes 中 Pod 的资源 request/limit
  • 或资源超限后的报警或自恢复机制设计
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

思静鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值