Linux下获取java堆栈文件并进行分析-简书

1、终端输入top命令,键盘大写的情况下按P(cpu负载率从高到低排序)或者M(内存使用率从高到低排序),可以查看导致cpu或者内存飙升的java pid。

2、jstack PID > jstack.log

上面的命令可以保存当前时刻的线程栈到 jstack.log 文件中(保存在当前路径下)

3、分析栈文件

3.1 grep 'java.lang.Thread.State' jstack.log  | wc -l

上述命令可以统计java.lang.Thread.State出现的次数

3.2  grep -A 1 'java.lang.Thread.State' jstack.log  | grep -v 'java.lang.Thread.State' | sort | uniq -c |sort -n

4、jmap -dump:format=b,file=heap.log pid

上述命令可以保存当前的堆情况到heap.log文件中。

下载Eclipse的内存分析工具,地址:https://www.eclipse.org/mat/downloads.php

下载完成后,双击MemoryAnalyzer.exe,点击Open a Heap Dump

选择桌面上的堆文件,点击打开:

选择第一个内存分析报告,然后点Finish:

如果文件太大导致失败,需要跳转MemoryAnalyzer.ini文件中JVM参数大小

就会打开一个总体情况页面:

点击左下角的Table Of Contents,里面有多种分析供选择:


 每一个选项几乎都有直观的饼状图显示对象的占用情况:

当然也有线程的堆使用情况分析,可以方便地找到占用大量内存的线程,找到真正导致内存、cpu飙升的罪魁祸首!

本文转载:https://www.cnblogs.com/stm32stm32/p/10539992.html
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容