https://segmentfault.com/a/1190000041541631
java内存分析一般采用Java jmap dump下系统内存文件,使用 jmat 进行分析。
线程栈一般通过 jstack 得到。
火焰图
arthas
火焰图做为cpu调试的神器,最早是openresty中被大神春哥开始应用,之后慢慢普及到各个语种当中,Java目前用的还不是很多。所以这里码字普及一下火焰图的安装和一些用法
首先需要下载火焰图工具
下载安装 FlameGraph
下载地址: https://github.com/cobblau/Fl...
这个是火焰图生成工具
还需要安装一个工具:perf-map
这里的perf-map 需要Java版本至少1.7以上
下载地址:http://www.github.com/jvm-pro...
cmake.
make
-XX:+PreserveFramePointer jvm参数
使用命令之后就是采集结果阶段:
使用命令
perf record -a -g -p 65269 -F 99 -- sleep 30
java -cp attach-main.jar:$JAVA_HOME/lib/tools.jar net.virtualvoid.perf.AttachOnce PID
perf script | stackcollapse-perf.pl | flamegraph.pl > process.svg
条越长越耗cpu,每一条点击进去都可以看到自己的子调用栈