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. 未来已来:云原生 Cloud Native

    作者:天知,原文链接 前言 自 2013 年容器(虚拟)技术(Docker)成熟后,后端的架构方式进入快速迭代的阶段,出现了很多新兴概念: 微服务 k8s Serverless IaaS:基础设施服务 ...

  2. 【30天自制操作系统】day04:C语言与目前执行流程图

    用 C 语言直接写入内存 原来依靠汇编 void io_hlt(void); void write_mem8(int addr, int data); void HariMain(void){ int ...

  3. Vscode LeetCode 教程

    1: 题目选区 商店安装LeetCode 以后, 选择地球确认选区 2: 选择题目 选择Code Now 进行编码 默认路径为$HOME/.leetcode/ 你可以通过更新配置项 leetcode. ...

  4. 大数据学习笔记——HBase使用bulkload导入数据

    HBase使用bulkload批量导入数据 HBase可使用put命令向一张已经建好了的表中插入数据,然而,当遇到数据量非常大的情况,一条一条的进行插入效率将会大大降低,因此本篇博客将会整理提高批量导 ...

  5. C#封装继承

    面向对象开发有三大特性(特点 / 特征) : 封装, 继承, 多态.我们今天主要讨论封装和继承,多态会在下篇中讨论. 一.封装: 所谓封装,也就是把客观事物封装成抽象的类,并且类可以把自己的数据和方法 ...

  6. Add the Scheduler Module 添加计划程序模块

    Important 重要 Scheduler requires the Event business class to be in your XAF application model. Follow ...

  7. JS---课程介绍 + JavaScript分三个部分

    Web API---课程介绍 DOM:     概念-----能够说出来--理解     作用----记住了----后来理解     回顾JS分几个部分---知道        DOM树---能够说出 ...

  8. Linux下安装及使用mysql

    (注:本人在centos7进行的安装及使用) 1.安装wget yum install wget 2.下载mysql安装包 wget http://repo.mysql.com/mysql57-com ...

  9. SQL索引碎片的产生,处理过程。

    本文参考 https://www.cnblogs.com/CareySon/archive/2011/12/22/2297568.html https://www.jb51.net/softjc/12 ...

  10. Navicat Premium 连接oracle 提示ORA-01017:用户名/口令无效;登陆被拒绝

    Navicat Premium 连接oracle,密码明明是对的,还是提示 ORA-01017:用户名/口令无效:登陆被拒绝.而用Pl/SQL 连接没有问题. 其实用户名和密码是对的,但还是会报错,这 ...