java查看dump信息(linux java dump文件分析命令)

发布时间:2022-11-10

本文目录一览:

  1. java visualvm 堆dump怎么分析
  2. Java 中怎么获取一份线程 dump 文件
  3. 如何查看javacore和heapdump文件

java visualvm 堆dump怎么分析

jmap是java自带的工具

  1. 查看整个JVM内存状态
    jmap -heap [pid]
    
  2. 查看JVM堆中对象详细占用情况
    jmap -histo [pid]
    
  3. 导出整个JVM 中内存信息,可以利用其它工具打开dump文件分析,例如jdk自带的visualvm工具
    jmap -dump:file=文件名.dump [pid]
    

Java 中怎么获取一份线程 dump 文件

当服务器挂起,崩溃或者性能底下时,就需要抓取服务器的线程堆栈(Thread Dump)用于后续的分析. Thread dump提供了当前活动的线程的快照。它提供了JVM中所有Java线程的栈跟踪信息。 有很多方式可用于获取Thread Dump,一些是操作系统特定的命令。

操作系统命令获取ThreadDump:

  • Windows:
    1. 转向服务器的标准输出窗口并按下Control + Break组合键,之后需要将线程堆栈复制到文件中
  • UNIX/ Linux:
    1. 首先查找到服务器的进程号(process id),然后获取堆栈。
      ps -ef | grep java
      kill -3 pid
      

      注意一定要谨慎,一步不慎就可能让服务器进程被杀死!

JVM 自带的工具获取线程堆栈:

  • JDK自带命令行工具获取PID并做ThreadDump:
    1. jps
      
    2. jstack pid
      
  • 使用JVisualVM: Threads 标签页 → ThreadDump按钮
  • WebLogic 自带的获取 thread dump的工具:
    1. webLogic.Admin 工具 a. 打开命令提示符,通过运行 DOMAIN_HOME/bin/setDomain.env 设置相关类路径 b. 执行下面的命令:
      java weblogic.Admin -url t3://localhost:7001 -username weblogic -password weblogic1 THREAD_DUMP
      

      注意: Thread Dump 会打印到标准输出,如nohup日志或者进程窗口。

    2. 使用 Admin Console a. 登录 Admin Console,点击对应的服务器 b. 点击 Server → Monitoring → Threads c. 点击: Dump Thread Stack 按钮
    3. 使用WLST (WebLogic Scripting Tool)
      connect('weblogic','weblogic1','t3://localhost:7001')
      cd('Servers')
      cd('AdminServer')
      threadDump()
      disconnect()
      exit()
      

      注意: 线程堆栈将会保存在运行wlst的当前目录下。

    4. 使用 utils.ThreadDumper 用法:
      C:\bea\wlserver_10.3\server\lib\java -cp weblogic.jar utils.ThreadDumper
      
      示例输出:
      Broadcast Thread dumps disabled: must specify weblogic.debug.dumpThreadAddr and
      weblogic.debug.dumpThreadPort
      Exception in thread "main" java.lang.IllegalArgumentException: Port out of range:-1
      at java.net.DatagramPacket.setPort(Unknown Source)
      at java.net.DatagramPacket.init(Unknown Source)
      at java.net.DatagramPacket.init(Unknown Source)
      at utils.ThreadDumper.sendDumpMsg(ThreadDumper.java:124)
      at utils.ThreadDumper.main(ThreadDumper.java:145)
      
    5. 如果服务器是作为Windows服务的方式运行,请运行下列命令:
      WL_HOME\bin\beasvc -dump -svcname:service-name
      
  • 其它一些获取Thread Dump的工具有jrcmd, jrmc(JRockit VM自带) ,Samurai, JProfiler等,还可通过JMX编程的方式获取,如JDK自带示例代码:
    $JAVA_HOME/demo/management/FullThreadDump
    

如何查看javacore和heapdump文件

一、查看javacore文件

  1. 下载 ThreadDumpAnalysergraphvizsvgviewer
  2. 运行以下命令:
    runall.bat javacore.txt
    
    会产生三个文件:
    • dumps.xml
    • locktree1.svg
    • sidebyside.html

二、查看heapdump文件

  1. 从IBM网站下载 ha433 包,解压后执行:
    java -jar ha433.jar
    
  2. ha433 窗口中打开 heapdump.phd,会显示分析结果。