java并发-一些系统分析工具

内存分析

java内存分析一般采用Java jmap dump下系统内存文件,使用 jmat 进行分析。

线程分析

线程栈一般通过 jstack 得到。

cpu分析

火焰图
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

安装完之后需要设置jvm 参数

-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,每一条点击进去都可以看到自己的子调用栈

你可能感兴趣的:(java)