在CentOS上使用Docker時,可以通過多種方式對容器的資源進行限制,包括CPU、內存、磁盤I/O和網絡帶寬等。以下是一些常用的方法:
docker run
命令的參數-c
或 --cpus
: 指定容器可以使用的CPU核心數。docker run -it --cpus=2 ubuntu:latest /bin/bash
-m
或 --memory
: 指定容器可以使用的最大內存量。docker run -it --memory="512m" ubuntu:latest /bin/bash
--blkio-weight
: 設置容器的塊設備I/O權重。docker run -it --blkio-weight=500 ubuntu:latest /bin/bash
--network
: 指定網絡模式(如 bridge
, host
等)。--device-read-bps
: 限制設備讀取速度。--device-write-bps
: 限制設備寫入速度。docker run -it --network=bridge --device-read-bps=/dev/sda:1mb ubuntu:latest /bin/bash
如果你使用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
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
你也可以通過修改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
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容器的資源限制。