docker 限制容器能够使用的资源
docker 限制容器能够使用的内存,CPU,I/O
资源概述,内存是非可压缩资源,cpu是可压缩资源。
- 内存用超了,就发送Out Of Memory Exception,容器会被kill掉。所以内存是不可压缩资源。
- cpu用超了,就在那里等待就好,容器不会被kill掉。所以CPU是可压缩资源。
一,控制容器所能使用的内存,内存分2部分,一部分是ram,一部分是swap
-m/--memory bytes: 指定ram的大小
--memory-swap bytes:指定swap的大小。前提是先指定了-m。
--memory-swap -m/--memory 说明 正数M1 正数M2 容器可以使用的总内存空间是M1,其中ram是M2,swap是M1-M2.若M1=M2,则无swap可用。 0 正数M ram为M;swap为unset unset 正数M ram为M;若宿主机启动了swap,则容器可以使用的swap为2*M -1 正数M ram为M;若宿主机启动了swap,则容器可以使用宿主机上所有的swap空间。 在容器里使用free看到的swap空间,没有任何意义。
--oom-kill-disable:使用的内存超出了指定值(Out Of Memory),一般情况下,这个容器会被kill掉。如果这个容器不希望被kill掉,则使用此选项。
--oom-score-adj int:从-1000 到 1000。当内核发现内存不够用了时,就会kill别的进程。内核有特定的算法,算出来oom-score,oom-score高的就会被优先kill掉,所以调低这个值,就不容易被内核kill掉。另外,docker daemon的oom-score就很低,防止被内核kill掉。所有容器的oom-score不要调的比docker daemon都低。
--memory-swappiness int:Tune container memory swappiness (0 to 100) (default -1)。使用swap的倾向性。0的话就不倾向使用swap,100就特别倾向使用swap。
--memory-reservation bytes:保留内存。必须低于-m指定的内存。
二,控制容器所能使用的CPU
- --cpu-shares int:可以使用的cpu时间片的比例份数。CPU shares (relative weight)
- --cpus decimal :可以使用CPU里的核心数,可以是小数。比如1.5.但不能指定具体使用哪个核心。
- --cpuset-cpus string:可以具体指定使用哪个核心。比如【1,3】,【0-3】.
三,压力测试
使用docker-stress-ng镜像,可以测试给容器分配的内存和CPU是否生效了。
docker run --name b1 -it --rm lorel/docker-stress-ng stress-ng --help
- docker stats 查看容器使用CPU的情况。
- docker top 查看容器使用内存的情况。
c/c++ 学习互助QQ群:877684253
本人微信:xiaoshitou5854
docker 限制容器能够使用的资源的更多相关文章
- [转帖]Docker容器CPU、memory资源限制
Docker容器CPU.memory资源限制 https://www.cnblogs.com/zhuochong/p/9728383.html 处理事项内容等 这一块内容感觉 不清楚.. 背景 在使用 ...
- Docker(二十)-Docker容器CPU、memory资源限制
背景 在使用 docker 运行容器时,默认的情况下,docker没有对容器进行硬件资源的限制,当一台主机上运行几百个容器,这些容器虽然互相隔离,但是底层却使用着相同的 CPU.内存和磁盘资源.如果不 ...
- Docker(十九)-Docker监控容器资源的占用情况
启动一个容器并限制资源 启动一个centos容器,限制其内存为1G ,可用cpu数为2 [root@localhost ~]# docker run --name os1 -it -m 1g --cp ...
- Docker容器CPU、memory资源限制
背景 在使用 docker 运行容器时,默认的情况下,docker没有对容器进行硬件资源的限制,当一台主机上运行几百个容器,这些容器虽然互相隔离,但是底层却使用着相同的 CPU.内存和磁盘资源.如果不 ...
- Docker监控容器资源的占用情况
启动一个容器并限制资源 启动一个centos容器,限制其内存为1G ,可用cpu数为2 [root@localhost ~]# docker run --name os1 -it -m 1g --cp ...
- Docker与容器快速入门
Docker之风席卷全球,但很多人觉得docker入门确实不太容易,其原因在于很多知识点上没准备好,在docker解决了什么问题.怎么解决的.用什么技术解决的都还没想清楚的时候就去探索docker组件 ...
- Docker系列之(三):Docker微容器Alpine Linux
1. 前言 使用Docker创建容器时,基础镜像通常选择Ubuntu或Centos,不管哪个镜像的大小都在100MB以上. Alpine Linux是一个面向安全的轻型的Linux发行版. Alpin ...
- Docker: 限制容器可用的内存
默认情况下容器使用的资源是不受限制的.也就是可以使用主机内核调度器所允许的最大资源.但是在容器的使用过程中,经常需要对容器可以使用的主机资源进行限制,本文介绍如何限制容器可以使用的主机内存. 为什么要 ...
- Docker: 限制容器可用的 CPU
默认情况下容器可以使用的主机 CPU 资源是不受限制的.和内存资源的使用一样,如果不对容器可以使用的 CPU 资源进行限制,一旦发生容器内程序异常使用 CPU 的情况,很可能把整个主机的 CPU 资源 ...
随机推荐
- 零基础想学习C语言,没资源、没人带、不知道从何开始?
初学编程的小伙伴经常会遇到的问题,1.没资源 2.没人带 3.不知道从何开始 ? 小编也是从新手期过来的,所以很能理解萌新的难处,现在整理一些以前自己学习买来的一些资料送给大家,希望对广大初学小伙伴有 ...
- Often Misused:Spring Remote Service 经常被误用:Spring远程服务
- 每天3分钟操作系统修炼秘籍(12):OOM和swap分区
点我查看秘籍连载 OOM和swap分区 进程的虚拟内存空间是映射到整个物理内存空间的,所以在进程自身看来它拥有了整个物理内存,它也能使用整个物理内存,只需在使用的时候请求操作系统帮忙分配更多空间即可. ...
- Html5 小游戏 俄罗斯方块
导言 在一个风和日丽的一天,看完了疯狂HTML 5+CSS 3+JavaScript讲义,跟着做了书里最后一章的俄罗斯方块小游戏,并做了一些改进,作为自己前端学习的第一站. 游戏效果: 制作思路 因为 ...
- JS 测试 Prototype
JS 测试 Prototype 测试 JavaScript 框架库 - Prototype 引用 Prototype 如需测试 JavaScript 库,您需要在网页中引用它. 为了引用某个库,请使用 ...
- CODING 受邀参与 DevOps 标准体系之系统和工具&技术运营标准技术专家研讨会
2019 年 5 月 24-25 日,国内领先的一站式 DevOps 解决方案供应商 CODING 作为腾讯云的深度合作伙伴,受邀参加在成都举行的由 TC608 云计算标准和开源推进委员会主办,中国信 ...
- Oracle11G_R2中共享服务器模式和专用服务器模式参数解释及设置
sys@MYTESTDB> show parameterNAME TYPE VALUE------------------------------------ ----------- ----- ...
- MySQL——my.cnf参数设置说明
以下为个人总结的MySQL配置文件参数说明,如有错误,烦请大佬们留言指正,本人将第一时间修改.2019-12-10 12:32:08 [mysqld] server- # Mysql唯一标识,一个集群 ...
- windows命令行pip报错解决的方法
今天在新电脑安装python,发现pip无效了,于是乎百度了很多方法,发现原因是pip升级导致的 解决办法,卸载pip重新安装 可以首先执行 python -m ensurepip 然后执行 py ...
- 基于V7的新版RL-USB V6.X + RL-FlashFS V6.X模板,操作CLASS10的SD卡速度12-15MB/S,含RTX5和FreeRTOS两版
说明: 1.如果需要RL-USB源码的话,将DAPLink(CMSIS-DAP)里面的USB代码导出来即可,DAPLink开源了RL-USB的Device代码. 也可以反过来,在工程模板的基 ...