桌面云虚拟机内存泄露排查
  

新手701029 67021人觉得有帮助

{{ttag.title}}
本帖最后由 新手701029 于 2020-12-12 17:36 编辑

问题现象:当虚拟机开机一段时间后内存占用很高,且通过任务管理器查看应用程序占用内存正常,关闭应用程序不能降低内存,系统弹出如下提示。
排查思路
1.确认是应用层发生内存泄漏,还是内核层发生泄漏,通过任务管理器的内存(专用工作集)或者工作设置(内存),大概查看是否是具体某个应用消耗了大量内存,如果是则查某个具体应用的内存泄露,这里暂时不讨论,否则就属于内核层发生内存泄露。

2.使用工具poolmon,可以查看内核层发生内存泄露。poolmon -a,是根据Allocs数量来排序,一般内存泄露的肯定是Allocs多,Frees少。执行该命令可以看到Limit是11G,Commit提交了也是接近11G,通过poolmon查看,发现内存tag为FMfn的模块消耗了9个G,查看Bytes列既可以看出,可以得出内存标记为FMfn的驱动模块发生内存泄露。Limit是可提交的最大内存数量,Commit是目前提交的数量。
4.查找内存标记为FMfn的驱动模块,发现内存标记为FMfn的驱动模块为fltMgr.sys,该驱动为系统提供的minifilter框架驱动,那就可能是系统各种的minifilter调用框架api,产生了内存分配,却没有释放导致。
5.使用fltmc命令查看系统中存在哪些minifilter。
6.逐个卸载重启测试,重启后使用poolmon查看内核内存消耗情况。这里当我们卸载360之后FMfn消耗正常,可以确定是360的驱动导致内核内存泄漏。



330775fd48b921bd08.png (933.88 KB, 下载次数: 34)

330775fd48b921bd08.png

打赏鼓励作者,期待更多好文!

打赏
33人已打赏

林明纲_福州办 发表于 2021-1-1 14:53
  
感谢楼主分享,很详细,有些情况直接通过任务管理器无法直接观察到被什么进程占用,用工具poolmon做内存泄漏分析。一些病毒导致内存占用高也可以用相同方法分析。
水之蓝色 发表于 2020-12-13 13:55
  
学习学习
剰悇の迗眞 发表于 2020-12-16 09:21
  
刚好最近有很多桌面云的项目,这篇帖子分析问题的很到位哦~~学习了
新手612152 发表于 2020-12-16 10:45
  
满满的干货,感谢分享
xinghuajx 发表于 2020-12-16 10:56
  
论工具的重要性。谢谢分享。
新手741261 发表于 2020-12-16 11:27
  
学习到了。感谢
JM 发表于 2020-12-16 11:42
  
来学习下楼主的成果
zqm 发表于 2020-12-16 16:07
  

论工具的重要性。 桌面云虚拟机内存泄露排查满满的干货,这篇帖子分析问题的很到位哦~~学习了感谢分享
78465 发表于 2020-12-16 19:40
  
满满的干货,感谢分享
新手564110 发表于 2020-12-22 16:51
  
满满的干货,感谢分享
发表新帖
热门标签
全部标签>
每日一问
技术盲盒
技术笔记
干货满满
技术咨询
功能体验
新版本体验
产品连连看
GIF动图学习
标准化排查
自助服务平台操作指引
运维工具
2023技术争霸赛专题
通用技术
秒懂零信任
技术晨报
信服课堂视频
用户认证
安装部署配置
深信服技术支持平台
安全攻防
SDP百科
设备维护
社区帮助指南
答题自测
每日一记
玩转零信任
畅聊IT
专家问答
技术圆桌
在线直播
MVP
网络基础知识
升级
上网策略
测试报告
日志审计
问题分析处理
流量管理
云计算知识
原创分享
解决方案
sangfor周刊
VPN 对接
项目案例
SANGFOR资讯
专家分享
技术顾问
信服故事
功能咨询
终端接入
授权
资源访问
地址转换
虚拟机
存储
迁移
加速技术
排障笔记本
产品预警公告
信服圈儿
S豆商城资讯
技术争霸赛
「智能机器人」
追光者计划
答题榜单公布
纪元平台
卧龙计划
华北区拉练
天逸直播
以战代练
山东区技术晨报
文档捉虫活动
齐鲁TV
华北区交付直播
每周精选

本版版主

468
220
32

发帖

粉丝

关注

本版达人

新手89785...

本周建议达人

YangZhe...

本周分享达人

runner

本周提问达人