centos

Docker在CentOS上的资源限制设置

小樊
36
2025-06-28 10:13:37
栏目: 智能运维

在CentOS上使用Docker时,可以通过多种方式对容器的资源进行限制,包括CPU、内存、磁盘I/O和网络带宽等。以下是一些常用的方法:

1. 使用 docker run 命令的参数

CPU限制

内存限制

磁盘I/O限制

网络带宽限制

2. 使用 Docker Compose

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

CPU和内存限制

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

磁盘I/O限制

version: '3'
services:
  web:
    image: nginx:latest
    deploy:
      resources:
        reservations:
          cpus: '0.5'
          memory: 256M
        limits:
          cpus: '1'
          memory: 512M
        device_read_bps:
          /dev/sda: 1mb
        device_write_bps:
          /dev/sda: 1mb

3. 使用 Docker Daemon 配置

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

编辑 /etc/docker/daemon.json 文件,添加以下内容:

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

然后重启Docker服务:

sudo systemctl restart docker

4. 使用 cgroups

Docker底层使用Linux的cgroups来管理资源。你可以直接操作cgroups来更细粒度地控制资源。

例如,创建一个新的cgroup并设置CPU和内存限制:

sudo cgcreate -g cpu,memory:/mygroup
echo $((2*102400)) | sudo tee /sys/fs/cgroup/cpu/mygroup/cpu.cfs_quota_us
echo 102400 | sudo tee /sys/fs/cgroup/cpu/mygroup/cpu.cfs_period_us
echo $((512*1024*1024)) | sudo tee /sys/fs/cgroup/memory/mygroup/memory.limit_in_bytes

然后将容器进程加入到这个cgroup中:

sudo cgclassify -g cpu,memory:mygroup <container_pid>

通过这些方法,你可以在CentOS上灵活地设置Docker容器的资源限制。

0
看了该问题的人还看了