【问题标题】:Limiting a Docker Container to a single cpu core将 Docker 容器限制为单个 cpu 核心
【发布时间】:2014-11-17 20:59:27
【问题描述】:

我正在尝试构建一个在一致条件下运行代码片段的系统,我认为这可能的一种方法是在具有相同布局的 docker 容器中运行各种程序,保留相同数量的内存等. 但是,我似乎无法弄清楚如何保持 CPU 使用率一致。

我似乎能找到的最接近的东西是“cpu 共享”,如果我理解文档,它会限制 cpu 的使用与系统上正在运行的其他容器/其他进程以及系统上可用的内容有关。它们似乎无法将容器限制为绝对的 cpu 使用量。

理想情况下,我想设置仅限于使用单个 cpu 核心的 docker 容器。这有可能吗?

【问题讨论】:

    标签: docker cpu-usage


    【解决方案1】:

    如果你使用较新版本的Docker,可以在docker run中使用--cpuset-cpus=""指定你要分配的CPU核数:

    docker run --cpuset-cpus="0" [...]
    

    如果您使用旧版本的 Docker (--lxc-conf 来配置分配的 CPU 内核:

    docker run --lxc-conf="lxc.cgroup.cpuset.cpus = 0" [...]
    

    在这两种情况下,只有第一个 CPU 内核可用于 docker 容器。这两个选项都记录在in the docker help

    【讨论】:

      【解决方案2】:

      我已尝试提供有关容器资源分配的教程。

      https://gist.github.com/afolarin/15d12a476e40c173bf5f

      【讨论】:

      • 仅链接的答案没有用,因为链接可能会失效。将相关信息放在答案中。
      猜你喜欢
      • 2021-03-29
      • 1970-01-01
      • 2014-12-08
      • 1970-01-01
      • 2016-08-19
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多