0

0

Linux如何排查内存不足OOME问题_LinuxOOM分析教程

冷炫風刃

冷炫風刃

发布时间:2025-12-01 14:06:06

|

201人浏览过

|

来源于php中文网

原创

首先通过dmesg或journalctl查看系统日志确认OOM事件,再用free和ps aux分析内存使用情况,定位高内存占用进程,接着通过/proc//smaps_rollup深入检查其内存行为,判断是正常资源需求还是内存泄漏,最后结合应用类型、配置(如JVM参数、vm.overcommit_memory)确定根源并采取优化代码、调整资源配置等措施解决。

linux如何排查内存不足oome问题_linuxoom分析教程

Linux系统出现内存不足(OOME)问题时,关键在于快速定位是哪个进程耗尽了内存,以及根本原因是什么。核心思路是从系统日志入手确认OOM事件,然后分析内存使用情况,最终锁定罪魁祸首。

查看系统日志确认OOM事件

当物理内存和Swap空间都耗尽时,内核的OOM Killer机制会被触发,强制终止一个或多个进程。这个过程会在内核日志中留下明确记录,是排查的第一步。

  • 使用dmesg命令:直接查看内核环形缓冲区的日志,这是最常用的方法。 dmesg -T | grep -i "killed process" 该命令会列出所有被OOM Killer杀死的进程,输出中包含进程名、PID、内存占用详情(如total-vm, anon-rss)和一个“score”值,分数越高的进程越可能被选中杀死。
  • 使用journalctl命令:对于使用systemd的现代Linux发行版,此命令能提供更结构化的日志查询。 journalctl --since "2025-11-26" | grep -i "out of memory" 你可以指定时间范围来缩小搜索区间,确保找到与服务崩溃时间点吻合的记录。

分析系统内存使用画像

在确认发生过OOM后,需要全面了解系统的内存分配状况,判断是应用正常占用还是存在泄漏。

沁言学术
沁言学术

你的论文写作AI助理,永久免费文献管理工具,认准沁言学术

下载
  • 检查整体内存状态:使用free -h命令查看概览。重点关注available(可用内存)一栏,即使free列显示为0,只要available不低,系统通常仍可正常运行。如果available非常低或接近于0,则表明系统确实面临内存压力。同时观察Swap的used量,高Swap使用率是内存不足的强烈信号。
  • 定位内存消耗大户:找出占用内存最多的进程。 ps aux --sort=-%mem | head -20 这条命令会按内存使用百分比从高到低排序,列出前20个进程,能快速帮你锁定可疑目标。也可以使用交互式工具top,启动后按M键按内存排序。
  • 深入分析特定进程:对怀疑的对象进行深度检查。 sudo cat /proc//smaps_rollup 替换为实际进程号。重点关注Rss(实际使用的物理内存)、Pss(分摊后的内存,更准确)和Private_Dirty(进程独占且已修改的内存)。如果Private_Dirty持续增长,基本可以断定存在内存泄漏。

确定根源并制定解决方案

找到高内存占用的进程后,下一步是判断其行为是否合理,并采取相应措施。

  • 判断是资源需求大还是内存泄漏:如果是数据库或Java应用等本应占用大量内存的服务,检查其配置(如JVM堆大小-Xmx)是否合理,是否超出了服务器的物理限制。如果是普通应用或其内存随时间推移不断增长而不释放,则很可能是代码层面的内存泄漏,需要用Valgrind、ASan等工具进行代码审计。
  • 考虑系统级配置影响:检查vm.overcommit_memory设置(通过sysctl vm.overcommit_memory),它决定了系统如何处理内存申请。值为2时最为严格,可能会因为计算的可分配内存不足而提前阻止应用启动或分配,这也是一种间接的“内存不足”表现。
  • 实施解决策略:根据诊断结果,选择增加物理内存、优化应用代码、调整服务资源配置(如容器内存限制)、优化数据结构,或改进内存管理策略(如避免一次性加载海量数据)。

基本上就这些,从日志到内存,再到进程和代码,层层递进就能把问题揪出来。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

837

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

741

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

736

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

399

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

3

2026.01.19

热门下载

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

精品课程

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

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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