温馨提示×

Docker在CentOS中如何进行资源限制

小樊
51
2025-09-11 17:04:33
栏目: 智能运维

在CentOS中使用Docker进行资源限制,可以通过以下几种方式来实现:

1. 使用 docker run 命令的参数

在启动容器时,可以使用 docker run 命令的参数来限制资源。

CPU 限制

  • -c--cpus: 限制容器可以使用的CPU核心数。
    docker run -it --cpus=2 ubuntu:latest /bin/bash 

内存限制

  • -m--memory: 限制容器可以使用的最大内存量。
    docker run -it --memory="512m" ubuntu:latest /bin/bash 

磁盘I/O限制

  • --blkio-weight: 设置容器的块设备I/O权重。
    docker run -it --blkio-weight=500 ubuntu:latest /bin/bash 

2. 使用 Docker Compose

如果你使用 Docker Compose 来管理多个容器,可以在 docker-compose.yml 文件中定义资源限制。

version: '3' services: web: image: nginx:latest deploy: resources: reservations: cpus: '0.5' memory: 256M limits: cpus: '1' memory: 512M 

3. 使用 cgroups

Docker 使用 Linux 的 cgroups(控制组)来限制容器的资源。你可以通过调整 cgroups 的配置来进一步细化资源限制。

查看 cgroups 配置

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

修改 cgroups 配置

你可以手动修改这些文件来调整资源限制,但通常不推荐这样做,因为这可能会影响 Docker 的正常运行。

4. 使用 Docker Daemon 配置

你也可以通过修改 Docker Daemon 的配置文件 /etc/docker/daemon.json 来全局设置资源限制。

{ "exec-opts": ["native.cgroupdriver=systemd"], "log-driver": "json-file", "log-opts": { "max-size": "100m" }, "storage-driver": "overlay2", "default-ulimits": { "nproc": { "Name": "nproc", "Hard": 65535, "Soft": 65535 }, "nofile": { "Name": "nofile", "Hard": 65535, "Soft": 65535 } } } 

总结

通过上述方法,你可以在 CentOS 中使用 Docker 进行资源限制,确保容器不会占用过多的系统资源。根据你的具体需求选择合适的方法进行配置。

0