标签:申请 bug flow 系统 遇到 虚拟 分配 一个 mit
overcommit_memory是一个内核对内存分配的一种策略。 具体可见/proc/sys/vm/overcommit_memory下的值
overcommit_memory取值又三种分别为0, 1, 2
overcommit_memory=0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
overcommit_memory=1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
overcommit_memory=2, 表示内核允许分配超过所有物理内存和交换空间总和的内存
当overcommit_memory=2的时候,它一般是代表的是系统中总的内存的百分比
CommitLimit = SwapTotal + MemTotal * overcommit_ratio
总的虚拟内存 = 总的交换分区 + 总的物理内存 * overcommit_ratio
这些信息可以到cat /proc/meminfo中看到, 可以通过上述的计算公式可以计算就可以获得系统的CommitLimit的值
Committed_AS代表了系统已经用了的内存情况
生产踩坑: Airflow新版的一个bug需要将overcommit_memory调整为1, 而Greenplum修改pg_hba.cfg文件后重启需要overcommit_memory为2。
Linux 内核参数Overcommit_memory(最近生产中Airflow和Greenplum有被这个参数坑到......)
标签:申请 bug flow 系统 遇到 虚拟 分配 一个 mit
原文地址:https://www.cnblogs.com/ronnieyuan/p/13207861.html