Docker 容器资源限制

在 Docker 中,可以通过多种方式对容器的资源使用进行限制,包括 CPU、内存、磁盘 I/O 等。

限制 cpu 资源

运行容器时可以通过指定以下参数来限制容器的 CPU 资源:

--cpuset - cpus:设置容器可以使用的 CPU 核心。

--cpu - shares:设置容器的 CPU 调度优先级。

示例:限制容器只能在主机的第 0 和第 1 个 CPU 核心上运行,并设置容器的 CPU 调度权重为 512,Docker 默认的 CPU 股份值是 1024,因此这个容器在与其他容器竞争 CPU 时,其优先级相对较低。

复制代码
# docker run -itd --name dcoker-cpu01 --cpuset-cpus 0,1 --cpu-shares 512 busybox
限制内存资源

运行容器时可以通过指定以下参数来限制容器的内存:

--memory 限制容器可用的内存。

示例:创建容器名为 busybox1,限制容器只能在主机的第 2 和第 3 个 CPU 核心上运行,限制容器可用的内存为 128 MB。

复制代码
# docker run -itd --name busybox1 --cpuset-cpus 2,3 --memory 128m busybox

验证:

查看容器 busybox1运行在哪些 cpu核上,内存限制为多少.

复制代码
# docker inspect --format '{{.State.Pid}}' busybox1    # 获取容器的pid
24493
# cat /proc/24493/status | grep Cpu                    # 查看该pid进程的状态信息
Cpus_allowed:    c
Cpus_allowed_list:    2-3
# docker inspect busybox1 | grep -e "Memory"           # 查看容器内存(单位为字节)
            "Memory": 134217728,
            "KernelMemory": 0,
            "KernelMemoryTCP": 0,
            "MemoryReservation": 0,
            "MemorySwap": 268435456,
            "MemorySwappiness": null,
# 如上容器 busybox1 如预期运行在第2、3个cpu核上, 内存资源限制为 128MiB
相关推荐
cdg==吃蛋糕3 小时前
solr cloud集群搭建 solr5+zookeeper
tcp/ip·docker·容器
段振轩4 小时前
Docker nginx容器部署前端项目。
前端·nginx·docker
conkl4 小时前
在ARM64 Ubuntu 20.04上部署Mailu邮件系统:深度排查Docker Bridge网络通信失败问题
linux·ubuntu·docker
Rinleren6 小时前
企业级 K8s 运维实战:集群搭建、微服务暴露(Ingress)、监控告警(Prometheus)全流程
java·容器·kubernetes
云游6 小时前
IP地址管理:docker方式部署phpIPAMv1.7.3
运维·docker·ip·ipv4·ipv6
小闫BI设源码7 小时前
Docker Swarm主机编排
运维·docker·容器·容器编排·docker compose·依赖管理·多服务启动
Reicher7 小时前
Docker的介绍和使用
运维·docker·容器
退役小学生呀8 小时前
二十一、DevOps:从零建设基于K8s的DevOps平台(二)
运维·docker·云原生·容器·kubernetes·devops
荣光波比10 小时前
Docker(一)—— Docker入门到精通:从基础概念到容器管理
运维·docker·容器·云计算
JanelSirry10 小时前
VMware+RockyLinux+ikuai+docker+cri-docker+k8s+calico BGP网络 自用 实践笔记(二)
笔记·docker·kubernetes