0

0

cat /proc/meminfo 里 Committed_AS 远大于物理内存+swap 的风险评估

冷漠man

冷漠man

发布时间:2026-01-18 13:02:02

|

955人浏览过

|

来源于php中文网

原创

committed_as远大于物理内存加swap说明oom风险极高,因其是内核估算的最坏情况下所需总内存(含未触碰的虚拟内存),超限意味着理论兜底能力已丧失。

cat /proc/meminfo 里 committed_as 远大于物理内存+swap 的风险评估

Committed_AS 远大于物理内存加 Swap,说明内核认为当前所有进程的内存申请总量已严重超出系统实际可提供资源,存在高 OOM 风险。

Committed_AS 的真实含义

Committed_AS 是内核对“最坏情况下所需物理内存+Swap 总量”的估算值,不是当前已用内存,而是假设所有进程都把它们申请的虚拟内存(包括 malloc 分配但未写入、mmap 的私有匿名页等)全部触碰一遍时,系统需要满足的总页数。它基于 overcommit 策略(默认 vm.overcommit_memory=0)动态计算,包含大量“可能永远不真正使用”的预留量。

知鹿匠
知鹿匠

知鹿匠教师AI工具,新课标教案_AI课件PPT_作业批改

下载

为什么远超会导致风险

  • 当实际内存访问激增(如批量初始化、日志刷盘、GC 触发大量写入),内核需兑现这些承诺,但物理内存和 Swap 已耗尽,会立即触发 OOM Killer
  • Swap 不足时,即使 Committed_AS ≤ Mem + Swap,若活跃页过多、Swap IO 跟不上,仍可能卡死;而 Committed_AS ≫ Mem + Swap 意味着连理论兜底能力都丧失
  • 某些工作负载(如 Java 应用 + 大堆 + UseContainerSupport 未设限、数据库 buffer pool 预分配)容易在启动或峰值期快速推高该值

如何判断是否真危险

不能只看 Committed_AS 绝对值,要结合以下三点交叉验证:

  • 看 CommitLimit:CommitLimit = (RAM + Swap) × vm.overcommit_ratio / 100(默认 overcommit_ratio=50),若 Committed_AS > CommitLimit,说明已突破内核允许的 overcommit 上限,OOM 几乎必然发生
  • 看 MemAvailable:比 MemFree 更真实反映可用内存,持续低于 5%~10% 且 Committed_AS 持续攀升,是紧急信号
  • 看进程行为:用 pmap -x 或 smaps 查看各进程的 RSS、PSS 和 Swap,确认是否有异常大而空闲的匿名映射(如未 touch 的 hugepage mmap、glibc malloc 的 arena 预留)

常见缓解方向

  • 调低 vm.overcommit_ratio(如设为 20~30),收紧 CommitLimit,让内核更早拒绝可疑分配(需配合应用侧优化)
  • 限制容器或 cgroup 内存上限(memory.limit_in_bytes),从源头阻止单个应用无节制申请
  • Java 应用启用 -XX:+UseContainerSupport 并设置 -XX:MaxRAMPercentage,避免 JVM 误判宿主机内存
  • 排查并关闭非必要服务,或调整其内存配置(如 PostgreSQL 的 shared_buffers、work_mem)

这个指标本身不直接导致崩溃,但它是一个明确的“信用透支预警”。一旦触发 OOM,内核随机 kill 进程不可控,关键服务中断难以预测。及时干预比事后恢复更重要。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

433

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

postgresql常用命令
postgresql常用命令

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。本专题为大家提供postgresql相关的文章、下载、课程内容,供大家免费下载体验。

163

2023.10.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1003

2023.11.02

postgresql常用命令有哪些
postgresql常用命令有哪些

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。更详细的postgresql常用命令,大家可以访问下面的文章。

213

2023.11.16

postgresql常用命令介绍
postgresql常用命令介绍

postgresql常用命令有l、d、d5、di、ds、dv、df、dn、db、dg、dp、c、pset、show search_path、ALTER TABLE、INSERT INTO、UPDATE、DELETE FROM、SELECT等。想了解更多postgresql的相关内容,可以阅读本专题下面的文章。

280

2023.11.20

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

213

2026.02.12

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

382

2023.06.29

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

32

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.7万人学习

Java 教程
Java 教程

共578课时 | 77.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号