您现在的位置是:首页 > 文章详情

Docker中使用火焰图FlameGraph分析JVM应用性能

日期:2019-07-19点击:670

前言

前面的文章,我们讲述了如何通过perf的方式对java程序进行性能剖析,并生成FlameGraph火焰图,但是实际生产中,很多企业会将java部署在docker容器当中,这时对docker内运行的java进程进行剖析便成为一件很麻烦的事情。

执行步骤

安装相关依赖

yum install -y git cmake gcc-c++ gcc perf

下载项目

git clone https://github.com/zrbcool/docker-flame-graphs.git

指定JAVA_HOME环境变量

export JAVA_HOME=/root/jdk1.8.0_181 export PATH=$JAVA_HOME/bin:$PATH

编译项目

cd docker-flame-graphs/ cmake . && make

找到你要分析的docker进程

docker ps | grep xxx

找到这个容器的进程Pid

docker inspect --format '{{.State.Pid}}' [CONTAINER_ID]

修改脚本当中的JAVA_HOME保证与容器内部的JAVA_HOME一致

vi bin/create-java-perf-map.sh export JAVA_HOME=/app/3rd/jdk/default

去掉脚本当中被注释的命令:

vi bin/docker-perf-top #删掉下面代码前面的注释 sudo perf top -p $host_pid

在docker-flame-graphs目录下,执行:

docker cp $(pwd) [CONTAINER_ID]:/docker-flame-graphs

然后需要确认你的JVM参数增加了-XX:+PreserveFramePointer,如果没有,需要增加并重启服务
现在所有的准备工作已经完成,让你的JVM进程运行一段时间完成JIT的预热
然后我们开始分析性能:

cd bin ./docker-perf-top [CONTAINER_ID] [JAVA_ID] ./docker-perf-java-flames [CONTAINER_ID] [JAVA_ID]

docker-perf-top效果

docker-perf-java-flames

svg图像可以下钻等操作,请打开链接查看点我

参考

https://github.com/jvm-profiling-tools/perf-map-agent/issues/50 https://blog.alicegoldfuss.com/making-flamegraphs-with-containerized-java/ https://github.com/mboussaa/docker-flame-graphs http://www.batey.info/docker-jvm-flamegraphs.html https://github.com/chbatey/perf-map-agent https://blog.alicegoldfuss.com/making-flamegraphs-with-containerized-java/ https://github.com/jvm-profiling-tools/perf-map-agent https://medium.com/netflix-techblog/java-in-flames-e763b3d32166 
原文链接:https://yq.aliyun.com/articles/710054
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章