百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Docker的CPU限制说明

wptr33 2025-01-13 18:25 22 浏览

Docker的CPU资源限制

首先要指出的是,CPU 资源通常比内存更灵活。当程序需要工作时,它会执行指令,cpu 会尽快处理这些指令,然后程序和 cpu 都会返回空闲状态,除非有更多工作要做。该程序可能会在一秒钟内使用一个 cpu 内核的百分之一,下一秒使用一个内核的 100%,然后回到空闲状态。

这是一个 cpu 利用率图表,描述了处理 Web 请求的应用程序的 cpu 使用情况。即使将使用情况聚合到分钟级别,我们也看到该程序在 1% 到 24% 的 cpu 利用率范围内运行。

程序的 CPU 使用率是高度量化的,并且在每秒“达到 100%”的许多非常短的突发中消耗。这意味着限制使用的策略可能与内存使用不同。服务器应用程序可能会在启动时静态分配内存,构建内存缓存,并以与处理工作负载不直接相关的其他方式消耗内存。

Docker 通过容器的 cgroup 向您公开两个主要的 Linux cpu 使用控制:

  • CPU份额
  • CPU配额

CPU份额

该cpu-shares选项允许您指定当争用 cpu 时容器将接收的 cpu 的相对份额。

当没有对 cpu 的争用时,无论“限制”是多少,容器都可以使用它想要的数量。

当存在争用时,配置为 2048 个 cpu 份额的容器将获得两倍于请求 1024 个 cpu 份额的容器的 cpu 时间。

资源cpu-shares约束功能从 Docker 的早期版本开始就可用。

让我们来看一个例子。我在一台有 4 个内核的机器上使用 Docker。

首先在一个终端中启动docker stats,仅显示容器名称、cpu 使用情况和内存使用情况:

docker stats --format "table {{.Name}}\t{{.CPUPerc}}\t{{.MemUsage}}\t{{.MemPerc}}"
在第二个终端中,启动第 6 章中使用的 Docker in Action“stresser”图像:

docker container run --name stresser-1024 \
    --cpu-shares 1024 \
    dockerinaction/ch6_stresser

Dockerstats命令显示stresser-1024容器使用了 398% 的 CPU——所有四个核心:

NAME                CPU %               MEM USAGE / LIMIT     MEM %
stresser-1024       398.29%             1.102MiB / 1.945GiB   0.06%

现在让我们看看当运行第二个具有两倍 CPU 份额的容器时会发生什么:

docker container run -d --name stresser-2048 \ --cpu-shares 2048 \ dockerinaction/ch6_stresser

并重启stresser-1024容器:

docker container start stresser-1024

现在有两个进程都想占用 100% 的 CPU 资源,Linux 将这些资源按比例分配给它们:

NAME                CPU %               MEM USAGE / LIMIT     MEM %
stresser-2048       263.26%             1.078MiB / 1.945GiB   0.05%
stresser-1024       131.42%             1.035MiB / 1.945GiB   0.05% 

事实上,stresser-2048获得的 cpu 是 (131%) 的两倍 (263% stresser-1024)。

请注意,虽然我们将 cpu 份额指定为所需处理器的隐含数量乘以 1024,但这并未将进程限制为一个或两个内核。机器上的四个核心都用上了。

如果要强制执行绝对限制,则需要指定 cpu 配额。

CPU配额

Docker 允许您通过 Docker 1.13 中引入的选项轻松配置绝对cpu 配额--cpus。此 cpu 配额指定容器在被限制之前有权使用的固定 cpu 份额。配额在容器的 cgroup 中定义,并由 Linux 的Completely Fair Scheduler强制执行。

让我们通过启动每个配额为 1 和 2 cpu 的 stresser 容器来查看它的实际效果:

docker container run -d --name stresser-1-cpus \
    --cpus 1 \
    dockerinaction/ch6_stresser
docker container run -d --name stresser-2-cpus \
    --cpus 2 \
    dockerinaction/ch6_stresser

现在统计数据显示了一个截然不同的故事:

NAME                CPU %               MEM USAGE / LIMIT     MEM %
stresser-1-cpus     100.17%             1.098MiB / 1.945GiB   0.06%
stresser-2-cpus     201.14%             1.07MiB / 1.945GiB    0.05%

压力程序仅限于我们指定的 CPU 数量。当一个程序用完配额时,Linux 内核会延迟运行该程序,直到配额得到补充。配额每 100 毫秒分配和执行一次。

应用 CPU 约束

cpu 份额和配额资源约束机制都是有用的。

CPU 份额可以帮助您在共享主机的容器化进程之间建立相对优先级。此外,由于 CPU 份额在绝对 CPU 约束选项之前可用,因此大多数容器编排器都知道如何使用以“millicores”表示的 cpu 份额。这些编排器将接受以毫核表示的请求或限制,在假设每个核值 1024 毫核的情况下寻找具有足够资源的容器主机,然后相应地为容器配置 cpu-shares。这近似于为许多用例指定一定数量的 cpu 的能力。

CPU 份额崩溃的地方之一是当您不希望容器在主机上没有争用时能够突破其份额。有许多有效的用例,例如:

防止隔离服务的负载测试在测试环境中使用整台机器,而该服务将只有部分机器用于生产
建立硬性预算,出于调度、安全、计费或会计原因限制服务可用的资源
还有其他几个 cpu 约束和应用它们的方法。查看Docker in Action 的第 6 章,第 2ed了解更多信息或点击回复并提出问题。

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...