当前位置: 首页 > web >正文

内存泄漏问题排查

项目引入:某个功能页面一直打开进行静态拷机,发现内存持续增长。

可以通过JConsole监测内存增长曲线:

-Dcom.sun.management.jmxremote

-Dcom.sun.management.jmxremote.port=YOUR_PORT

-Dcom.sun.management.jmxremote.authenticate=false

-Dcom.sun.management.jmxremote.ssl=false

-Djava.rmi.server.hostname=YOUR_SERVER_IP

然后输出一下堆内存快照,通过MAT进一步分析:

jmap: jmap -dump:live,format=b,file=<filename>.hprof <pid>

jcmd: jcmd <pid> GC.heap_dump <filename>.hprof

同时查看一下Full GC频率:

jstat -gc <pid> [interval] [count]

  • S0C 和 S1C:Survivor区0和Survivor区1的当前容量(字节)。
  • S0U 和 S1U:Survivor区0和Survivor区1的已用空间大小。
  • EC 和 EU:Eden区的当前容量及其已用空间大小。
  • OC 和 OU:老年代的当前容量及其已用空间大小。
  • MC 和 MU:Metaspace的当前容量及其已用空间大小(在Java 8及以上版本中,永久代被Metaspace取代)。
  • CCSC 和 CCSU:压缩类空间的当前容量及其已用空间大小。
  • YGC 和 YGCT:年轻代GC事件的总次数及其总耗时(秒)。
  • FGC 和 FGCT:Full GC事件的总次数及其总耗时(秒)。
  • GCT:所有GC事件的总耗时(秒),等于YGCT加FGCT

MAT打开Heap Dump文件,查看Dominator Tree的引用链,哪个对象占用对空间最大

经分析,最终定位到2处泄漏的地方:一处是 JNI回调方法中,由于这些方法被频繁地调用,处理JNI对象时候生成了部分局部引用一直被占用未被释放;另一处是一个静态Map一直被占用,处理LRUCache的数据并存放到Map,由于size过大还没处理完又不断有新请求进来,强引用太多,调用方法阻塞。

除修改泄漏处代码外,调整了部分JVM参数,如下:

// 设置G1垃圾收集器触发一次混合垃圾回收周期时整个堆占用率的阈值

-XX:InitiatingHeapOccupancyPercent=25 

// G1启用字符串去重功能以减少内存占用

-XX:+UseStringDeduplication

// 设置G1垃圾收集器允许的最大堆浪费比例

-XX:G1HeapWastePercent=10

// 设置应该预留的堆空间百分比

-XX:G1ReservePercent=20

-XX:ParallelRefProcEnabled

// 设置尝试达到的目标最大GC停顿时间

-XX:MaxGCPauseMillis=100

// 设置 Eden 区与单个 Survivor 区的比例

-XX:SurvivorRatio=6

// 设置 Minor GC 后 Survivor 区(To Space)预期的占用比例

-XX:MaxTenuringThreshold=15

http://www.xdnf.cn/news/16558.html

相关文章:

  • Context Engineering Notes
  • 【Golang】Go语言运算符
  • 迷宫生成与路径搜索(A算法可视化)
  • Triton IR
  • Libevent(4)之使用教程(3)配置
  • 如何使用ozone调试elf文件?
  • Dify 本地化部署深度解析与实战指南
  • LangChain实现RAG
  • 力扣 hot100 Day57
  • 第四科学范式(数据密集型科学):科学发现的新范式
  • Qt C++动态库SDK在Visual Studio 2022使用(C++/C#版本)
  • IIS发布.NET9 API 常见报错汇总
  • Java面试实战:从基础到架构的全方位技术交锋
  • add新增管理员功能、BaseController类的简介--------示例OJ
  • PDF转图片实用指南:如何批量高效转换?
  • AI入门学习-模型评估示例讲解
  • Deja Vu: 利用上下文稀疏性提升大语言模型推理效率
  • 【java】 IntelliJ IDEA高效编程设置指南
  • Day06–哈希表–242. 有效的字母异位词,349. 两个数组的交集,202. 快乐数,1. 两数之和
  • EMCCD相机与电可调变焦透镜的同步控制系统设计与实现
  • 基于Matlab自适应阈值分割算法的图像处理研究
  • 《Java 程序设计》第 7 章 - 继承与多态
  • 嵌入式学习日志————对射式红外传感器计次
  • 高速采集卡FPGA设计方案及代码
  • 【测试报告】博客系统(Java+Selenium+Jmeter自动化测试)
  • maven命令详解
  • Element表格单元格类名动态设置
  • 可控、安全、可集成:安防RTSP|RTMP视频播放模块工程实践参考
  • Android基础(一) 运行HelloWorld
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘ipywidgets’问题