阅读docker-compose
规范(https://github.com/compose-spec/compose-spec/blob/master/spec.md#cpus)它说该cpus
选项已弃用,所以即使我使用它时它仍然有效,我认为它这不是一个好主意。
中央处理器
已弃用:使用 deploy.reservations.cpus
cpus 定义分配给服务容器的(可能是虚拟的)CPU 的数量。这是一个小数。0.000 表示没有限制。
另一方面,docker run
文档说(https://docs.docker.com/config/containers/resource_constraints/#configure-the-default-cfs-scheduler)该--cpus
选项更方便。
指定与 --cpu-quota 一起使用的 CPU CFS 调度程序周期。默认为 100000 微秒(100 毫秒)。大多数用户不会更改默认设置。对于大多数用例, --cpus 是一种更方便的选择。
所以我很困惑:我应该或不应该cpus
在 docker-compose 中使用吗?如果不这样做,我如何有效地控制服务 cpu 的使用?
我正在使用没有 swarm 的 docker。
语境
$ docker version
Client:
Version: 20.10.2
API version: 1.41
Go version: go1.13.8
Git commit: 20.10.2-0ubuntu1~20.04.2
Built: Tue Mar 30 21:24:57 2021
OS/Arch: linux/amd64
Context: default
Experimental: true
Server:
Engine:
Version: 20.10.2
API version: 1.41 (minimum version 1.12)
Go version: go1.13.8
Git commit: 20.10.2-0ubuntu1~20.04.2
Built: Mon Mar 29 19:10:09 2021
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: 1.3.3-0ubuntu2.3
GitCommit:
runc:
Version: spec: 1.0.2-dev
GitCommit:
docker-init:
Version: 0.19.0
GitCommit:
$ docker-compose version
docker-compose version 1.29.2, build 5becea4c
docker-py version: 5.0.0
CPython version: 3.7.10
OpenSSL version: OpenSSL 1.1.0l 10 Sep 2019