news 2026/7/2 4:14:59

Linux vm.overcommit_memory 参数的三种模式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux vm.overcommit_memory 参数的三种模式
cat/etc/sysctl.conf|grepvm.overcommit_memory
  • 作用:查看系统内存超量分配(overcommit)的配置策略
  • 输出示例
    vm.overcommit_memory=0# 或者vm.overcommit_memory=1# 或者vm.overcommit_memory=2
  • 如果没输出:表示使用内核默认值(通常是 0)

vm.overcommit_memory 的三种模式

模式 0(默认):试探性超量分配

vm.overcommit_memory=0

工作机制

  1. 内核试探性允许超量分配
  2. 使用启发式算法检查:
    允许分配=(空闲内存+可回收缓存+Swap)× overcommit_ratio+特殊保留
  3. 可能拒绝大内存申请(特别是 >50% 总内存)

适合场景:大多数通用服务器和工作站

模式 1:总是允许超量分配

vm.overcommit_memory=1

极端策略

  • 从不拒绝任何 malloc() 请求
  • 假设应用程序不会使用所有申请的内存
  • 可能触发OOM Killer随机杀进程

风险

# 场景:8GB内存的系统应用程序A申请:6GB(实际使用1GB)应用程序B申请:6GB(实际使用1GB)# 也被允许!应用程序C申请:6GB(实际使用1GB)# 也被允许!# 结果:申请了18GB,远超出物理内存,最终OOM

使用场景

  • 科学计算(知道内存使用模式)
  • 特定优化场景
  • 不推荐生产环境使用

模式 2:禁止超量分配

vm.overcommit_memory=2

严格策略

  • 内存分配不能超过
    允许总量 = Swap空间 + 物理内存 × overcommit_ratio
  • 默认 overcommit_ratio = 50%
  • 计算示例(8GB内存 + 8GB Swap):
    允许总量 = 8GB + 8GB × 50% = 8GB + 4GB = 12GB

优点

  • 防止内存过度申请
  • 更可预测的内存行为

缺点

  • 可能过早拒绝内存申请
  • 需要合理配置 Swap 和 ratio

相关配置参数

overcommit_ratio(默认 50%)

# 查看当前值cat/proc/sys/vm/overcommit_ratio# 输出: 50# 配置示例:允许使用60%物理内存用于超量分配vm.overcommit_ratio=60

overcommit_kbytes

# 以字节为单位的绝对限制(优先级高于ratio)vm.overcommit_kbytes=10485760# 10GB限制

查看当前状态

# 1. 查看当前overcommit设置cat/proc/sys/vm/overcommit_memory# 2. 查看内存超量分配统计cat/proc/meminfo|grep-i commit# 输出示例:CommitLimit:16257644kB# 系统允许分配的最大内存Committed_AS:10238456kB# 当前已申请的内存总量

实际配置示例

场景1:数据库服务器优化

# /etc/sysctl.conf# 禁止超量分配,确保内存可靠性vm.overcommit_memory=2# 允许使用70%物理内存 + 全部Swapvm.overcommit_ratio=70# 让配置生效sysctl -p

场景2:HPC/科学计算集群

# 知道应用会申请大量内存但使用不多vm.overcommit_memory=1# 配合cgroup限制,防止单个应用失控

场景3:内存紧张的虚拟机

# 严格限制,避免OOMvm.overcommit_memory=2vm.overcommit_ratio=40# 保守设置vm.swappiness=10# 减少Swap使用倾向

故障诊断命令

# 查看OOM相关日志dmesg|grep-i"out of memory\|oom"# 查看内存分配失败统计grep-r"alloc failed"/var/log/# 监控内存申请情况watch-n1'grep -E "CommitLimit|Committed_AS" /proc/meminfo'

最佳实践建议

  1. 生产服务器:建议使用模式 2,配合合理 Swap
  2. 默认值(模式 0)适合大多数场景
  3. 模式 1 要谨慎:确保有完善的监控和进程管理
  4. 重要提示:修改后需要执行sysctl -p生效

常见问题排查

# 问题:应用报"cannot allocate memory"但free显示有内存# 可能原因:overcommit_memory=2且CommitLimit已满# 解决:查看当前限制cat/proc/meminfo|grepCommit# 临时提高限制(重启失效)echo80>/proc/sys/vm/overcommit_ratio

核心理解vm.overcommit_memory控制的是内存申请的许可策略,而不是实际使用。Linux 允许程序申请比物理内存更多的空间,因为很多程序申请后并不立即使用全部。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 10:26:25

OpenCode版本升级:新特性迁移指南

OpenCode版本升级:新特性迁移指南 1. 引言 1.1 技术背景与升级动因 OpenCode 自 2024 年开源以来,凭借其“终端优先、多模型支持、隐私安全”的设计理念,迅速在开发者社区中获得广泛认可。项目以 Go 语言构建,采用客户端/服务器…

作者头像 李华
网站建设 2026/7/1 23:23:19

LessMSI(MSI安装包查看和提取工具)

LessMSI是开源、轻量级的工具,基于.NET构建,集图形界面和命令行接口于一体。它主要用于查看、提取、解析和管理MSI文件的内容,无需安装原始应用程序,为开发人员、系统管理员以及IT专业人员在软件部署和管理过程中提供了极大的便利…

作者头像 李华
网站建设 2026/7/1 8:44:13

软件测试入门必知必会的7个测试工具

一、功能测试:Selenium 为什么必学? 行业标准:Web自动化测试的事实标准 生态丰富:支持多语言(Java/Python/C#)、多浏览器 就业刚需:90%的自动化测试岗位要求掌握 入门示例 from selenium import webdriver from …

作者头像 李华
网站建设 2026/6/24 18:06:32

python之lession4

Python对象 一、不可变对象 Number数字 String字符串从上述代码中可以看出,不能够改变字符串的内容,但是可以改变str这个变量指向的位置 Tuple元组可以看到Tuple的指向是可以修改的,就是Tuple这个元组的变量名字tuple1,你可以决定…

作者头像 李华
网站建设 2026/7/1 10:24:25

校园墙小程序 表白墙

目录校园墙小程序表白墙摘要开发技术源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!校园墙小程序表白墙摘要 校园墙小程序中的表白墙是一个专为学生设计的匿名社交功能,旨在提供情感表达和互动的平台。用户可以通过匿名或公…

作者头像 李华