linux vm.overcommit_memory 内存分配参数 简介

vm.overcommit_memory是Linux内核控制内存分配策略的参数,可取0、1、2三个值。0表示内核尝试估算剩余内存,1允许超量使用直到耗尽,2使用严格算法限制分配。设置为1时,内存分配总是成功;设置为2时,分配会依据vm.overcommit_ratio进行限制。非root进程在分配时会保留额外空间。设置方法包括修改sysctl.conf、使用sysctl命令或直接写入/proc/sys/vm/overcommit_memory。

目录

vm.overcommit_memory 参数解释

设置方法


vm.overcommit_memory 表示内核在分配内存时候做检查的方式。
这个变量可以取到0,1,2三个值。对取不同的值时的处理方式都定义在内核源码 mm/mmap.c 的 __vm_enough_memory 函数中。

vm.overcommit_memory 参数解释


默认值为:0

从内核文档里得知,该参数有三个值,分别是:

0:当用户空间请求更多的的内存时,内核尝试估算出剩余可用的内存。

1:当设这个参数值为1时,内核允许超量使用内存直到用完为止,主要用于科学计算

2:当设这个参数值为2时,内核会使用一个决不过量使用内存的算法,即系统整个内存地址空间不能超过swap+50%的RAM值,50%参数的设定是在overcommit_ratio中设定。

​​​​​​​
  • 取 1 的时候:此时宏为 OVERCOMMIT_ALWAYS,函数直接 return 0,分配成功。

  • 取 2 的时候:此时宏为 OVERCOMMIT_NEVER,内核计算:内存总量×vm.overcommit_ratio/100+SWAP 的总量,如果申请空间超过此数值,则分配失败。vm.overcommit_ratio 的默认值为50。

  • 取 0 的时候:此时宏为 OVERCOMMIT_GUESS,内核计算:NR_FILE_PAGES 总量+SWAP总量+slab中可以释放的内存总量,如果申请空间超过此数值,则将此数值与空闲内存总量减掉 totalreserve_pages(?) 的总量相加。如果申请空间依然超过此数值,则分配失败。

以上为粗略描述,在实际计算时,如果非root进程,则在计算时候会保留3%的空间,而root进程则没有该限制

设置方法

方法1

编辑/etc/sysctl.conf ,改vm.overcommit_memory=1,然后sysctl -p使配置文件生效          

永久的,重启之后,仍然生效

方法2

sysctl  vm.overcommit_memory=1 或sysctl  -w  vm.overcommit_memory=1              

临时的,重启之后,又恢复为原来的样子

方法3

echo 1 > /proc/sys/vm/overcommit_memory                        

临时的,重启之后,又恢复为原来的样子

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值