侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

详解Docker cpu限制分析

Docker  /  管理员 发布于 7年前   310

本文测试了,Docker容器限制cpu资源使用的几个配置参数。分别使用top和dstat命令分析了资源占有情况。

package mainimport (  "flag"  "runtime"  "fmt")func main() {  cpunum := flag.Int("cpunum", 0, "cpunum")  flag.Parse()  fmt.Println("cpunum:", *cpunum)  runtime.GOMAXPROCS(*cpunum)  for i := 0; i < *cpunum - 1; i++ {    go func() {      for {      }    }()  }  for {  }}

制作了一个测试cpu占用的镜像,镜像默认占满1个核心

FROM busyboxCOPY ./full_cpu /full_cpuRUN chmod +x /full_cpuENTRYPOINT ["/full_cpu", "-cpunum"]CMD ["1"]docker build -t fangfenghua/cpuuseset .docker push fangfenghua/cpuusesetdocker info...Default Runtime: runcSecurity Options: seccompKernel Version: 3.10.0-229.el7.x86_64Operating System: CentOS Linux 7 (Core)OSType: linuxArchitecture: x86_64CPUs: 4Total Memory: 993.3 MiBName: localhost.localdomainID: TU6M:E6WM:PZDN:ULJX:EWKS:   ...
docker run -it --rm=true fangfenghua/cpuuseset [root@localhost src]# toptop - 07:23:52 up 1:23, 2 users, load average: 0.61, 1.12, 1.04Tasks: 154 total,  3 running, 145 sleeping,  6 stopped,  0 zombie%Cpu(s): 18.0 us, 0.1 sy, 0.0 ni, 81.8 id, 0.0 wa, 0.0 hi, 0.1 si, 0.0 stKiB Mem : 1017144 total,  422120 free,  171676 used,  423348 buff/cacheKiB Swap: 1040380 total, 1040284 free,    96 used.  688188 avail Mem  PID USER   PR NI  VIRT  RES  SHR S %CPU %MEM   TIME+ COMMAND     20196 root   20  0  3048  720  460 R 101.7 0.1  0:37.56 full_cpu       1 root   20  0  41536  4028  2380 S  0.0 0.4  0:02.60 systemd       2 root   20  0    0   0   0 S  0.0 0.0  0:00.04 kthreadd       3 root   20  0    0   0   0 S  0.0 0.0  0:00.48 ksoftirqd/0     5 root    0 -20    0   0   0 S  0.0 0.0  0:00.00 kworker/0:0H     7 root   rt  0    0   0   0 S  0.0 0.0  0:00.69 migration/0  docker run -it --rm=true fangfenghua/cpuuseset 4top - 07:27:17 up 1:27, 2 users, load average: 2.41, 1.47, 1.18Tasks: 159 total,  3 running, 145 sleeping, 11 stopped,  0 zombie%Cpu(s): 99.6 us, 0.2 sy, 0.0 ni, 0.0 id, 0.0 wa, 0.0 hi, 0.3 si, 0.0 stKiB Mem : 1017144 total,  402508 free,  190908 used,  423728 buff/cacheKiB Swap: 1040380 total, 1040284 free,    96 used.  668608 avail Mem  PID USER   PR NI  VIRT  RES  SHR S %CPU %MEM   TIME+ COMMAND     20935 root   20  0  3048  720  452 R 400.0 0.1  0:55.80 full_cpu       1 root   20  0  41620  4088  2380 S  0.0 0.4  0:02.88 systemd       2 root   20  0    0   0   0 S  0.0 0.0  0:00.04 kthreadd 

在Linux 系统上,可以用来限制docker容器资源占用的参数有:

  • --cpu-period int              Limit CPU CFS (Completely Fair Scheduler) period
  • --cpu-quota int               Limit CPU CFS (Completely Fair Scheduler) quota
  • -c, --cpu-shares int              CPU shares (relative weight)
  •  --cpuset-cpus string          CPUs in which to allow execution (0-3, 0,1)

docker提供了Ccpu-period、Ccpu-quota两个参数控制容器可以分配到的CPU时钟周期。Ccpu-period是用来指定容器对CPU的使用要在多长时间内做一次重新分配,而Ccpu-quota是用来指定在这个周期内,最多可以有多少时间用来跑这个容器。跟Ccpu-shares不同的是这种配置是指定一个绝对值,而且没有弹性在里面,容器对CPU资源的使用绝对不会超过配置的值。

cpu-period和cpu-quota的单位为微秒(μs)。cpu-period的最小值为1000微秒,最大值为1秒(10^6 μs),默认值为0.1秒(100000 μs)。cpu-quota的值默认为-1,表示不做控制。

举个例子,如果容器进程需要每1秒使用单个CPU的0.2秒时间,可以将cpu-period设置为1000000(即1秒),cpu-quota设置为200000(0.2秒)。当然,在多核情况下,如果允许容器进程需要完全占用两个CPU,则可以将cpu-period设置为100000(即0.1秒),cpu-quota设置为200000(0.2秒)。

使用本文制作的容器镜像来测试,cpu-period和cpu-quota两个参数吧。

在本文使用的4核心系统中,如果希望cpuusetest占满两个核心,在如何配置呢?从上文的分析中可以看到,如果将cpu-period设置为100000,那么期望占满4个核心,则需要将cpu-quota设置为4*100000,期望占满一个核心则可设置为2*100000。下面就测试一下吧:

docker run --name cpuuse -d --cpu-period=100000 --cpu-quota=200000 fangfenghua/cpuusetest 4top - 07:46:31 up 1:46, 2 users, load average: 0.16, 0.21, 0.51Tasks: 168 total,  2 running, 142 sleeping, 24 stopped,  0 zombie%Cpu(s): 47.8 us, 0.1 sy, 0.0 ni, 51.9 id, 0.1 wa, 0.0 hi, 0.1 si, 0.0 stKiB Mem : 1017144 total,  364724 free,  227816 used,  424604 buff/cacheKiB Swap: 1040380 total, 1040284 free,    96 used.  631052 avail Mem  PID USER   PR NI  VIRT  RES  SHR S %CPU %MEM   TIME+ COMMAND     21766 root   20  0  3048  724  464 R 193.3 0.1  1:00.37 full_cpu       1 root   20  0  41620  4088  2380 S  0.0 0.4  0:03.13 systemd       2 root   20  0    0   0   0 S  0.0 0.0  0:00.05 kthreadd       3 root   20  0    0   0   0 S  0.0 0.0  0:00.52 ksoftirtop - 07:47:17 up 1:47, 2 users, load average: 0.47, 0.26, 0.51Tasks: 172 total,  3 running, 144 sleeping, 25 stopped,  0 zombie%Cpu(s): 99.6 us, 0.1 sy, 0.0 ni, 0.3 id, 0.0 wa, 0.0 hi, 0.1 si, 0.0 stKiB Mem : 1017144 total,  358760 free,  233292 used,  425092 buff/cacheKiB Swap: 1040380 total, 1040284 free,    96 used.  625180 avail Mem docker run --name cpuuse -d --cpu-period=100000 --cpu-quota=400000 fangfenghua/cpuusetest 4 PID USER   PR NI  VIRT  RES  SHR S %CPU %MEM   TIME+ COMMAND     21976 root   20  0  3048  724  456 R 398.3 0.1  0:16.81 full_cpu     21297 root   20  0    0   0   0 S  0.3 0.0  0:00.08 kworker/0:2     1 root   20  0  41620  4088  2380 S  0.0 0.4  0:03.19 systemd       2 root   20  0    0   0   0 S  0.0 0.0  0:00.05 kthreadd 

使用上述两个参数可以,设置cpu的精确控制。还有一个参数cpu-share,是个相对值。假如设置A容器cpu-share为1536,设置B容器为512。那么,在容器B启动前,cpu占用情况为是什么呢?

top - 07:56:10 up 1:56, 2 users, load average: 0.75, 0.36, 0.50Tasks: 153 total,  3 running, 140 sleeping, 10 stopped,  0 zombie%Cpu(s): 99.7 us, 0.1 sy, 0.0 ni, 0.0 id, 0.0 wa, 0.0 hi, 0.3 si, 0.0 stKiB Mem : 1017144 total,  436300 free,  155616 used,  425228 buff/cacheKiB Swap: 1040380 total, 1040284 free,    96 used.  703544 avail Mem  PID USER   PR NI  VIRT  RES  SHR S %CPU %MEM   TIME+ COMMAND     22216 root   20  0  3048  720  456 R 399.3 0.1  0:55.03 full_cpu       1 root   20  0  41620  4088  2380 S  0.0 0.4  0:03.29 systemd       2 root   20  0    0   0   0 S  0.0 0.0  0:00.05 kthreadd       3 root   20  0    0   0   0 S  0.0 0.0  0:00.54 ksoftirqd/0 

启动容器B:

top - 07:57:09 up 1:57, 2 users, load average: 3.55, 1.16, 0.76Tasks: 162 total,  4 running, 148 sleeping, 10 stopped,  0 zombie%Cpu(s): 99.6 us, 0.2 sy, 0.0 ni, 0.0 id, 0.0 wa, 0.0 hi, 0.3 si, 0.0 stKiB Mem : 1017144 total,  428772 free,  158304 used,  430068 buff/cacheKiB Swap: 1040380 total, 1040284 free,    96 used.  700444 avail Mem  PID USER   PR NI  VIRT  RES  SHR S %CPU %MEM   TIME+ COMMAND     22216 root   20  0  3048  720  456 R 305.7 0.1  4:40.78 full_cpu     22336 root   20  0  3048  720  460 R 95.3 0.1  0:09.02 full_cpu       1 root   20  0  41620  4088  2380 S  0.0 0.4  0:03.31 systemd 

从上述测试结果不难看出。设置相对数值时,容器B启动之前,容器A仍然占满了cpu,而容器B启动后则,容器占3/4,容器B占1/4。

还有一个参数cpu-sets,指定容器使用的核心。使用上述测试容器测试,指定容器使用0,3核心:

docker run --name cpuuse -d --cpuset-cpus=0,3 fangfenghua/cpuusetest 4

0,3核心占用率:

[root@localhost src]# dstat -c -C 0,3-------cpu0-usage--------------cpu3-usage------usr sys idl wai hiq siq:usr sys idl wai hiq siq 25  9 66  0  0  0: 12  1 87  0  0  0100  0  0  0  0  0:100  0  0  0  0  0 99  0  0  0  0  1:100  0  0  0  0  0 99  1  0  0  0  0: 99  1  0  0  0  0100  0  0  0  0  0:100  0  0  0  0  0100  0  0  0  0  0:100  0  0  0  0  0

1,2核心占用率:

[root@localhost src]# dstat -c -C 1,2-------cpu1-usage--------------cpu2-usage------usr sys idl wai hiq siq:usr sys idl wai hiq siq 21  8 71  0  0  0: 10  1 89  0  0  0 0  0 100  0  0  0: 0  0 100  0  0  0 0  0 100  0  0  0: 0  0 100  0  0  0 0  0 100  0  0  0: 0  0 100  0  0  0 0  0 100  0  0  0: 0  0 100  0  0  0

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    Docker容器内存限制的方法
    下一条:
    详解Docker 容器使用 cgroups 限制资源使用
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在docker环境中实现Laravel项目执行定时任务和消息队列流程步骤(0个评论)
    • 在MacBook下laravel项目多php版本docker开发环境配置方案(0个评论)
    • 在docker环境中部署docker部署elk架构流程步骤(1个评论)
    • docker compose跟Dockerfile的区别浅析(0个评论)
    • Ubuntu 22.04系统中安装podman流程步骤(1个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-11
    • 2020-06
    • 2021-05
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-11
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客