• docker容器之限制内存


    1、为什么要限制内存?

    一个 docker host 上会运行若干容器,每个容器都需要 CPU、内存和 IO 资源。对于 KVM,VMware 等虚拟化技术,用户可以控制分配多少 CPU、内存资源给每个虚拟机。对于容器,Docker 也提供了类似的机制避免某个容器因占用太多资源而影响其他容器乃至整个 host 的性能。

    2、如何进行内存的限制?

    与操作系统类似,容器可使用的内存包括两部分:物理内存和 swap。
    a、-m 或 --memory:设置内存的使用限额,例如 100M, 2G。
    b、--memory-swap:设置 内存+swap 的使用限额。
    eg:docker run -m 200M --memory-swap=300M ubuntu
    其含义是允许该容器最多使用 200M 的内存和 100M 的 swap。默认情况下,上面两组参数为 -1,即对容器内存和 swap 的使用没有限制。

    3、如何进行内存限制的测试?

    使用 progrium/stress 镜像来学习如何为容器分配内存。该镜像可用于对容器执行压力测试。执行如下命令:
    docker run -it -m 200M --memory-swap=300M progrium/stress --vm 1 --vm-bytes 280M
    --vm 1:启动 1 个内存工作线程。
    --vm-bytes 280M:每个线程分配 280M 内存。
    正常运行
    docker run -it -m 200M --memory-swap=300M progrium/stress --vm 1 --vm-bytes 310M
    分配的内存超过限额,stress 线程报错,容器退出。
    ps:如果在启动容器时只指定 -m 而不指定 --memory-swap,那么 --memory-swap 默认为 -m 的两倍,比如:
    docker run -it -m 200M ubuntu
    容器最多使用 200M 物理内存和 200M swap。

  • 相关阅读:
    english note(6.3 to 6.8)
    english note(6.2 to 5.30)
    Lambda表达式
    Python Software Foundation
    eval(input())
    北航操作系统实验2019:Lab4-1代码实现参考
    北航操作系统实验2019:Lab4-1流程梳理
    面向对象设计与构造2019 第二单元总结博客作业
    面向对象设计与构造2019 第一单元总结博客作业
    Java代码度量分析工具:Designite简介
  • 原文地址:https://www.cnblogs.com/Richardo-M-Q/p/14009748.html
Copyright © 2020-2023  润新知