zoukankan      html  css  js  c++  java
  • centos7下安装docker(9容器对资源的使用限制-内存)

                  一个docker Host上面会运行若干容器,每个容器都需要CPU,内存和IO资源。容器提供了控制分配多少CPU,内存给每个容器的机制,避免摸个容器因占用太多资源而影响其他容器乃至整个Host的性能。

    内存限额

    与操作系统类似:容器使用的内存包括两部分:物理内存和swap内存

    1.可以使用参数来控制容器内存的使用量

          -m或者是--memory:设置内存使用限额,例如:100M,2G

          --memory-swap : 设置内存+swap的使用限额(总内存)

    设置物理内存为400M swap内存为100M

    2.使用progrium/stress镜像 来分配容器内存,progrium/stress可用于对容器内存执行压力测试

    下载镜像

    运行一个progrium/stress镜像的容器

    --vm 1:启动一个线程

    --vm-bytes 280M :为这个线程分配280M内存

    因为280M内存在300M范围内,所以能够正常运行,其过程是:

    1.分配280M内存

    2.释放280M内存

    3.再分配280M内存

    4.释放280M内存

    5.一直循环下去。。。。。

    但是当我们运行一个比内存大的线程时,系统是否正常?

    由于分配的内存超过限额,stress线程报错,容器退出

     当我们在运行容器只指定了-m而没有指定--memory-swap时,--memory-swap默认是-m指定的两倍

    使用docker 的-m的参数进行容器内存分配的时候,内核可能会出现一下错误:

    Your kernel does not support swap limit capabilities.memory limit without swap:这是由于内核不支持限制内存的设置

    解决办法是:vim /etc/default/grub

    修改为:

    或者:GRUB_CMDLINE_LINUX="cgroup_enable=memory swapaccount=1"

    重启后可以解决

  • 相关阅读:
    Spring5源码--Spring AOP使用接口方式实现 配置xml文件
    什么是 JavaConfig?
    Spring Boot 有哪些优点?
    什么是 Spring Boot?
    问:一台客户端有三百个客户与三百个客户端有三百个客户对服务器施压,有什么区别?
    如何实现参数级联查询
    如何开发主从报表
    如何在报表中实现算法的可挂接需求
    如何实现报表的批量打印需求
    如何实现参数和报表间的联动效果
  • 原文地址:https://www.cnblogs.com/lkun/p/7724317.html
Copyright © 2011-2022 走看看