码迷,mamicode.com
首页 > Web开发 > 详细

jcmd、jstack、jmap抓包

时间:2018-04-03 11:29:17      阅读:629      评论:0      收藏:0      [点我收藏+]

标签:jcmd   jstack   jmap   

jcmd是从JDK 7开始引入的一个JVM诊断命令行工具,可以向运行中的JVM发送诊断命令

在保证了JDK版本的前提下,欲使Linux上下载下来的jfr文件能在本地运行,还需要在搭有Linux环境的服务器JVM中添加如下参数:

-XX:+UnlockCommercialFeatures
-XX:+FlightRecorder

resin

<jvm-arg>-XX:+UnlockCommercialFeatures</jvm-arg>
<jvm-arg>-XX:+FlightRecorder</jvm-arg>

然后在Linux环境上运行如下命令生成jfr文件:

su www -lc "/usr/java/jdk1.7.0_40/bin/jcmd ${ppid} JFR.start name=test duration=60s settings=default.jfc filename=output_`date +%m%d%H%M`.jfr"

待文件生成成功后,下载相应的jfr双击即可查看相关信息。(代码->热点方法->堆栈跟踪)

使用到的其它命令如下:

  jcmd                           ----查看JVM进程的PID
  jcmd -l                        
  jcmd pid Thread.print   ----打印堆栈信息,功能类似于jstack -m pid

其他:

jstack线程:(632是进程ID)

su www -lc "/usr/java/jdk1.7.0_40/bin/jstack 632" > /home/www/jstack_out.txt

jmap内存:

su www -lc "jmap -F -dump:format=b,file=jmap.dat 6214"
查看
su www -lc "jhat -j -Xmx512m -port 9998 /home/www/jmap.dat"

jcmd、jstack、jmap抓包

标签:jcmd   jstack   jmap   

原文地址:http://blog.51cto.com/chaichuan/2094094

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!