在CentOS上限制Docker容器的资源使用,可以通过以下几种方式实现:
docker run 命令的参数你可以在启动容器时使用 docker run 命令的参数来限制资源使用。
docker run --cpus=1 my_image 这会限制容器最多使用1个CPU核心。
docker run --memory=512m my_image 这会限制容器最多使用512MB的内存。
docker run --cpus=1 --memory=512m my_image docker update 命令如果你已经启动了一个容器,可以使用 docker update 命令来更新其资源限制。
docker update --cpus=1 my_container docker update --memory=512m my_container 如果你使用 Docker Compose 来管理容器,可以在 docker-compose.yml 文件中指定资源限制。
version: '3' services: my_service: image: my_image deploy: resources: reservations: cpus: '0.5' memory: 256M limits: cpus: '1' memory: 512M Docker 使用 Linux 的 cgroups(控制组)来限制容器的资源使用。你可以手动配置 cgroups 来更精细地控制资源分配。
cat /sys/fs/cgroup/cpu/docker/<container_id>/cpu.shares cat /sys/fs/cgroup/memory/docker/<container_id>/memory.limit_in_bytes echo 536870912 > /sys/fs/cgroup/memory/docker/<container_id>/memory.limit_in_bytes 如果你使用 systemd 来管理 Docker 服务,可以在 systemd 服务文件中设置资源限制。
sudo vi /etc/systemd/system/my_service.service [Service] ExecStart=/usr/bin/docker run --cpus=1 --memory=512m my_image sudo systemctl daemon-reload sudo systemctl restart my_service 通过以上几种方法,你可以在CentOS上有效地限制Docker容器的资源使用。选择哪种方法取决于你的具体需求和使用场景。