• Linux 内核参数Overcommit_memory(最近生产中Airflow和Greenplum有被这个参数坑到......)


    1. overcommit_memory是什么?

      overcommit_memory是一个内核对内存分配的一种策略。 具体可见/proc/sys/vm/overcommit_memory下的值
    

    2. overcommit_memory有什么作用?

     overcommit_memory取值又三种分别为0, 1, 2
    
    overcommit_memory=0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
    overcommit_memory=1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
    overcommit_memory=2, 表示内核允许分配超过所有物理内存和交换空间总和的内存
    

    3. overcommit_ratio是什么?

    当overcommit_memory=2的时候,它一般是代表的是系统中总的内存的百分比
    

    4. 虚拟内存

    CommitLimit = SwapTotal + MemTotal * overcommit_ratio

    总的虚拟内存 = 总的交换分区 + 总的物理内存 * overcommit_ratio

    这些信息可以到cat /proc/meminfo中看到, 可以通过上述的计算公式可以计算就可以获得系统的CommitLimit的值

    5. Committed_AS:是什么?

    Committed_AS代表了系统已经用了的内存情况

    6. overcommit_memory的系统默认值是0, overcommit_ratio的默认值是50。可以实际中会遇到相同配置的电脑,相同的程序一个可以申请到内存,一个不可一申请到。这时候可以看看overcommit_memory的值是否被修改了。

    生产踩坑: Airflow新版的一个bug需要将overcommit_memory调整为1, 而Greenplum修改pg_hba.cfg文件后重启需要overcommit_memory为2。

  • 相关阅读:
    for 循环遍历字典中的键值两种方法
    python print函数之end
    python中的lambda匿名函数和reduce、filter、map函数
    python2.7 python3.3 cmd命令行 运行同一段代码内存地址为什么不一样?而用同一个解释器运行的内存地址都一样
    Eclipse快捷键
    Sass基础(二)
    Sass基础(一)
    浅谈JavaScript原型
    浅谈Javascript闭包
    Bootstrap学习笔记(四)
  • 原文地址:https://www.cnblogs.com/ronnieyuan/p/13207861.html
Copyright © 2020-2023  润新知