0

0

Linux 内存泄漏排查技巧与案例

舞夢輝影

舞夢輝影

发布时间:2026-02-22 18:45:02

|

486人浏览过

|

来源于php中文网

原创

内存泄漏的判定关键是看内存增长是否持续且不可逆:如进程rss持续上涨、重启归零,或sunreclaim单向爬升;slab中obj size固定且active持续增加(如dentry_cache)是典型信号。

linux 内存泄漏排查技巧与案例

怎么看是不是内存泄漏,而不是单纯吃内存

内存占用高不等于泄漏,关键看增长是否持续且不可逆。比如 top 里某个进程 RSS 持续上涨、重启后归零,或者系统空闲时 /proc/meminfo 中的 SlabSUnreclaim 单向爬升,这才是泄漏信号。常见假阳性:缓存(SReclaimable 高通常没事)、BuffersCached —— 它们会在内存压力下自动回收;而 SUnreclaim 长期不降,基本就是内核态泄漏了。

实操建议:

  • 先跑 watch -n 1 'cat /proc/meminfo | grep -E "^(MemFree|Slab|SReclaimable|SUnreclaim)'",盯 5–10 分钟,看哪项在涨
  • 对比 slabtop -o(按 c 排序),重点关注 OBJ SIZE 固定、ACTIVE 持续增加的 cache,比如 dentry_cachesize-4096
  • 如果用户进程没几个但 Slab 占几 G,基本可以排除应用层,直奔内核模块或驱动

valgrind 能用,但别在生产环境硬上

valgrind --tool=memcheck 是排查 C/C++ 用户态泄漏最直接的工具,但它会拖慢程序 20–30 倍,且无法检测内核内存分配(kmallocalloc_page)。更麻烦的是,它依赖符号表和调试信息,strip 过的二进制基本没法用。

实操建议:

  • 编译时加 -g -O0(开发/测试环境),避免优化干扰堆栈追踪
  • 运行前设 export MALLOC_CHECK_=2,能提前捕获部分 free 误用
  • 重点看日志里 definitely loststill reachable —— 前者是真泄漏,后者可能是全局指针未清,需结合代码判断
  • 别用 valgrind 查 systemd 服务或容器 init 进程:它会拦截 fork,导致子进程失效

内核泄漏怎么定位到具体函数

用户态工具失灵时,/proc/slabinfo 和 tracepoint 是唯二靠谱路径。比如发现 size-4096 cache 不停涨,说明有内核路径反复调用 kmalloc(4096) 却漏掉 kfree。这时候靠 trace-cmd 抓调用栈比猜快得多。

Linux+PHP+MySQL案例教程
Linux+PHP+MySQL案例教程

本书以培养高级网站建设与管理人才为目标,内容循序渐进,由浅入深,通过大量的实例系统全面地介绍了Linux+PHP+MySQL环境下的网络后台开发技术。本书详尽分析了近30个典型案例。包括计数器、网站流量统计、留言板、论坛系统、聊天室、投票与调查、用户管理、新闻发布系统、广告轮播、购物系统等等,力求让读者通过对案例的学习,轻松掌握PHP和MySQL的编程精要,迅速掌握网络后台开发技巧。   本书适

下载

实操建议:

  • 先确认泄漏对象:grep "size-4096" /proc/slabinfo,看 num_objs 是否随时间增加
  • 开 trace:trace-cmd record -e kmem:kmalloc -e kmem:kfree -F -C --filter "bytes == 4096"-F 强制 flush,防丢事件)
  • 跑几分钟后 trace-cmd report,过滤出只有 kmalloc 没对应 kfreeptr 地址
  • crash 工具读 vmcore 或直接 cat /proc/kcore | dd skip=$((0xffff880423744000)) count=4096 2>/dev/null | strings 看那块内存里存的是什么(比如 /proc/schedstat 字符串就暴露了来源)

curl、NSS、dentry 这类“第三方组件泄漏”最容易被忽略

很多内存泄漏根本不在你的代码里,而在你调用的库中。典型案例如 curl 7.19.7 + NSS 组合,在 HTTPS 探测时会不断创建 dentry 对象却不释放,表现为 Slab 高但业务无异常。这类问题不会报错,日志也干净,纯靠内存曲线和 slabtop 对象分布才能揪出来。

实操建议:

  • 查版本:用 curl -Vldd ./your_binary | grep nssrpm -q nss 确认三方组件实际版本
  • 搜已知缺陷:关键词组合如 "curl dentry leak""nss sdb cache leak",Linux 社区和 curl bugzilla 里常有现成 patch 或绕过方案(如 NSS_SDB_USE_CACHE=1
  • 临时验证:停掉可疑脚本或服务,观察 SUnreclaim 是否停止增长;再用 echo 2 > /proc/sys/vm/drop_caches 清 slab(仅限测试,生产慎用)

真正难的不是工具怎么用,而是得意识到:泄漏可能藏在你从没看过源码的库里,而且它只在特定路径(比如 HTTPS + 某个 NSS 版本 + 某种证书格式)下触发。盯着自己代码找三天,不如花十分钟查下依赖组件的已知 issue。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

246

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

826

2024.03.01

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

199

2023.11.20

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

452

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

182

2023.10.30

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

616

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

217

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1557

2023.10.24

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.5万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

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

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