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 限制容器能够使用的资源的更多相关文章

  1. [转帖]Docker容器CPU、memory资源限制

    Docker容器CPU.memory资源限制 https://www.cnblogs.com/zhuochong/p/9728383.html 处理事项内容等 这一块内容感觉 不清楚.. 背景 在使用 ...

  2. Docker(二十)-Docker容器CPU、memory资源限制

    背景 在使用 docker 运行容器时,默认的情况下,docker没有对容器进行硬件资源的限制,当一台主机上运行几百个容器,这些容器虽然互相隔离,但是底层却使用着相同的 CPU.内存和磁盘资源.如果不 ...

  3. Docker(十九)-Docker监控容器资源的占用情况

    启动一个容器并限制资源 启动一个centos容器,限制其内存为1G ,可用cpu数为2 [root@localhost ~]# docker run --name os1 -it -m 1g --cp ...

  4. Docker容器CPU、memory资源限制

    背景 在使用 docker 运行容器时,默认的情况下,docker没有对容器进行硬件资源的限制,当一台主机上运行几百个容器,这些容器虽然互相隔离,但是底层却使用着相同的 CPU.内存和磁盘资源.如果不 ...

  5. Docker监控容器资源的占用情况

    启动一个容器并限制资源 启动一个centos容器,限制其内存为1G ,可用cpu数为2 [root@localhost ~]# docker run --name os1 -it -m 1g --cp ...

  6. Docker与容器快速入门

    Docker之风席卷全球,但很多人觉得docker入门确实不太容易,其原因在于很多知识点上没准备好,在docker解决了什么问题.怎么解决的.用什么技术解决的都还没想清楚的时候就去探索docker组件 ...

  7. Docker系列之(三):Docker微容器Alpine Linux

    1. 前言 使用Docker创建容器时,基础镜像通常选择Ubuntu或Centos,不管哪个镜像的大小都在100MB以上. Alpine Linux是一个面向安全的轻型的Linux发行版. Alpin ...

  8. Docker: 限制容器可用的内存

    默认情况下容器使用的资源是不受限制的.也就是可以使用主机内核调度器所允许的最大资源.但是在容器的使用过程中,经常需要对容器可以使用的主机资源进行限制,本文介绍如何限制容器可以使用的主机内存. 为什么要 ...

  9. Docker: 限制容器可用的 CPU

    默认情况下容器可以使用的主机 CPU 资源是不受限制的.和内存资源的使用一样,如果不对容器可以使用的 CPU 资源进行限制,一旦发生容器内程序异常使用 CPU 的情况,很可能把整个主机的 CPU 资源 ...

随机推荐

  1. 一文带你深入了解JVM性能调优以及对JVM调优的全面总结

    目录 JVM调优 概念 基本垃圾回收算法 垃圾回收面临的问题 分代垃圾回收详述1 分代垃圾回收详述2 典型配置举例1 典型配置举例2 新一代的垃圾回收算法 调优方法 反思 一.JVM调优的一些概念 数 ...

  2. 技术分享预告丨k3s在边缘计算中的应用实践

    技术分享是在[Rancher官方微信技术交流群]里以图文直播+QA实时互动的方式,邀请国内已落地经验的公司或团队负责人分享生产落地的最佳实践.记得添加微信小助手(微信号:rancher2)入群,实时参 ...

  3. 图像的相似度Hash算法

    Hash算法有三种,分别为平均哈希算法(aHash).感知哈希算法你(pHash)和差异哈哈希算法(dHash). 针对以上三种的Hash算法详解见博客园文章 https://www.cnblogs. ...

  4. Linux笔记16 使用Vsftpd服务传输文件;使用Samba或NFS实现文件共享。

    FTP协议有下面两种工作模式. 1.主动模式:FTP服务器主动向客户端发起连接请求. 2.被动模式:FTP服务器等待客户端发起连接请求(FTP的默认工作模式).Vsftpd服务程序vsftpd作为更加 ...

  5. 跨平台版本迁移之 XTTS 方案操作指南

    本文转自 https://blog.csdn.net/Enmotech/article/details/80045576 作者 | 罗贵林: 云和恩墨技术工程师,具有8年以上的 Oracle 数据库工 ...

  6. Cocos2d-x3.0网络通信学习(一)

    配置:win7+Cocos2d-x.3.0+VS2012 摘要:建立基本的http通信并得到返回信息. 一.添加项目与编译库 1.添加头文件 在需要用到Http网络相关类的文件中加入头文件 #incl ...

  7. 苹果 macOS 安装 Source Code Pro

    1. 下载     到 Source Code Pro 的 GitHub 官网下载:https://github.com/adobe-fonts/source-code-pro 点击 GitHub 中 ...

  8. yii2 提示

    控制器中: Yii::$app->getSession()->setFlash('success', "描述!"); Yii::$app->getSession( ...

  9. js中call、apply、bind到底有什么区别?bind返回的方法还能修改this指向吗?

     壹 ❀ 引 同事最近在看angularjs源码,被源码中各种bind,apply弄的晕头转向:于是他问我,你知道apply,call与bind的区别吗?我说apply与call是函数应用,指定thi ...

  10. 磕磕绊绊中,使用Git工具完成代码上传

    1.安装Git工具 1)下载并安装Git工具:Git下载地址 安装完成之后,在桌面空白处点击右键,会出现以下选项: 2.初始化环境 1) 在一文件夹中,点击右键,选择上图中的Git Bash Here ...