centos

Docker在CentOS上的资源限制与分配

小樊
40
2025-06-12 06:09:15
栏目: 智能运维

Docker在CentOS上的资源限制与分配可以通过以下几种方式进行:

1. 使用docker run命令的参数

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

CPU限制

内存限制

内存交换限制

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配置

echo 512000 > /sys/fs/cgroup/cpu/docker/<container_id>/cpu.shares
echo 536870912 > /sys/fs/cgroup/memory/docker/<container_id>/memory.limit_in_bytes

4. 使用Docker Daemon配置

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

{
  "default-ulimits": {
    "memlock": {
      "Name": "memlock",
      "Hard": -1,
      "Soft": -1
    },
    "nproc": {
      "Name": "nproc",
      "Hard": 65535,
      "Soft": 65535
    },
    "nofile": {
      "Name": "nofile",
      "Hard": 65535,
      "Soft": 65535
    }
  }
}

修改配置后,重启Docker服务以使更改生效:

systemctl restart docker

注意事项

通过以上几种方式,你可以在CentOS上有效地限制和分配Docker容器的资源。

0
看了该问题的人还看了