news 2026/2/23 19:53:08

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/2/4 16:03:59

[特殊字符] AI印象派艺术工坊技术深挖:OpenCV算法底层原理简析

🎨 AI印象派艺术工坊技术深挖:OpenCV算法底层原理简析 1. 技术背景与问题提出 在数字图像处理领域,非真实感渲染(Non-Photorealistic Rendering, NPR)一直是连接计算机视觉与艺术表达的重要桥梁。传统基于深度学习的…

作者头像 李华
网站建设 2026/2/8 4:30:32

一份小而精的项目范围说明书,让交付成功率翻倍

关于作者 张秀玲,潮宏基集团商学院负责人,PMP国际项目经理,2024年中国企业学习发展杰出贡献者,汕头大学商学院工程管理专业硕士校外导师。 企业大学实战搭建者,跨业态干部训战落地专家,团队提质与业绩增长双…

作者头像 李华
网站建设 2026/2/23 11:56:47

GLM-ASR-Nano-2512功能全测评:支持WAV/MP3/FLAC/OGG多格式

GLM-ASR-Nano-2512功能全测评:支持WAV/MP3/FLAC/OGG多格式 1. 项目背景与核心价值 随着语音识别技术在智能助手、会议记录、内容创作等场景的广泛应用,对高精度、低延迟且支持多格式输入的本地化ASR(自动语音识别)模型需求日益增…

作者头像 李华
网站建设 2026/2/19 8:47:17

通过7个关键技巧,让你的论文重复率从78%降至8%。

在深夜面对查重报告的高重复率时,很多人会感到束手无策,尤其是经历过将论文重复率从28%降至8%的繁琐过程后,更渴望找到高效解决方案。通过7种经过实践验证的降重技巧,可以快速优化论文内容,显著降低重复率,…

作者头像 李华
网站建设 2026/2/20 19:23:05

亲测好用8个AI论文平台,自考学生轻松搞定毕业论文!

亲测好用8个AI论文平台,自考学生轻松搞定毕业论文! AI 工具如何成为自考学生的论文好帮手 随着人工智能技术的不断发展,越来越多的自考学生开始借助 AI 工具来提升论文写作效率。尤其是在面对繁重的学术任务时,这些工具不仅能帮助…

作者头像 李华