news 2026/6/10 7:02:16

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/6/9 22:16:19

Windows平台USB Serial驱动下载:新手教程指南

告别“未知设备”:Windows下USB转串口驱动配置实战指南 你有没有遇到过这样的场景? 手里的开发板插上电脑,设备管理器里却只显示一个孤零零的“ 未知设备 ”,COM端口迟迟不出现。明明线接对了,电源也亮了&#xff…

作者头像 李华
网站建设 2026/6/10 0:28:38

2种方法,教你使用Python实现接口自动化中的参数关联

通常在接口自动化中,经常会参数关联的问题,那么什么是参数关联? 参数关联就是上一个接口的返回值会被下一个接口当做参数运用,其中Python中可以实现参数关联的方法有很多种,今天小编给大家介绍下,如何通过…

作者头像 李华
网站建设 2026/6/10 0:29:41

完整指南:MySQL与PostgreSQL触发器调试技巧

深入数据库内核:MySQL 与 PostgreSQL 触发器调试实战全解析你有没有遇到过这样的场景?一条看似正常的INSERT语句突然报错“库存不足”,但查遍应用代码却找不到任何校验逻辑;或者发现某张表的更新总是慢得离谱,排查半天…

作者头像 李华
网站建设 2026/6/9 17:28:10

PyTorch开发踩坑记录:正确使用镜像才能发挥最大效能

PyTorch开发踩坑记录:正确使用镜像才能发挥最大效能 1. 引言:为什么选择合适的开发镜像是关键 在深度学习项目中,环境配置往往是开发者面临的第一个挑战。一个不兼容或配置不当的环境可能导致训练失败、性能低下甚至系统崩溃。本文基于实际…

作者头像 李华
网站建设 2026/6/9 21:08:07

基于协同过滤算法的美食点餐分享推荐系统小程序

目录协同过滤算法在美食点餐推荐系统中的应用系统架构与功能设计技术实现与优化应用价值与展望项目技术支持可定制开发之功能亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作协同过滤算法在美食点餐推荐系统中的应用 协同过滤算法通过分…

作者头像 李华
网站建设 2026/6/9 17:24:56

基于微信小程序的家政服务平台

目录微信小程序家政服务平台摘要项目技术支持可定制开发之功能亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作微信小程序家政服务平台摘要 微信小程序家政服务平台是基于移动互联网技术的便捷服务解决方案,旨在为用户提供高…

作者头像 李华