使用VisualVM从Java中的远程应用程序获取堆转储

时间:2009-04-07 16:56:36

标签: java monitoring heap jvisualvm

我运行JVisualVM(Windows XP,Sun Java 1.6.0.13,32位客户端VM)来监控远程应用程序(Linux,Sun Java 1.6.0.07,64位服务器VM)。在启动实际的远程应用程序之前,我使用所有访问策略在远程计算机jstatd上启动:

grant codebase "file:${java.home}/../lib/tools.jar" {
   permission java.security.AllPermission;
};

然后我使用命令行启动实际的应用程序

 java -Dcom.sun.management.jmxremote.authenticate=false 
-Dcom.sun.management.jmxremote.ssl=false 
-Dcom.sun.management.jmxremote.port=3333 
compileTest.Main

从客户端计算机上,我可以看到远程应用程序并对其进行监控。我也可以进行线程转储等。遗憾的是,堆转储按钮显示为灰色。

如何使用JVisualVM从远程监控的应用程序获取堆转储?

我尝试使用jConsole。使用jConsole,可以使用com.sun.management.HotSpotDiagnostic dumpHeap操作进行远程堆转储。我希望将转储转移到客户端,并使用JVisualVM提供的工具进行分析。我怎么能这样做?

4 个答案:

答案 0 :(得分:7)

有办法做到这一点!

  1. rmiregistry -J-Xbootclasspath / p:$ JAVA_HOME / lib / sa-jdi.jar(这使用端口1099)
  2. 在运行应用程序的计算机上启动'jsadebugd':jsadebugd& (JVM的pid)
  3. 在远程机器上使用以下 jmap -dump:file =:1099

  4. jhat

  5. 以上将在7000端口启动Web应用程序

    以上所有工具都是JDK 1.6的一部分

    一切顺利!

答案 1 :(得分:3)

不幸的是,没有一种自动化的方法可以做到这一点。您必须在Linux服务器上手动运行jmap以转储JVM的堆,然后将生成的堆转储复制到运行JVisualVM的本地计算机,并使用File | Load ...将堆转储装入JVisualVM进行分析。

答案 2 :(得分:2)

从1.3开始,VisualVM支持远程堆转储:

  

从VisualVM 1.3开始,您现在可以使用工具中的堆转储操作和按钮来进行远程运行的应用程序的堆转储。调用时,将显示一个对话框,使您可以指定要转储堆的远程系统上的完整路径。创建堆转储后,您需要手动将文件复制到本地计算机,并使用“加载”操作使用VisualVM打开和分析文件。

请参阅:VisualVM 1.3 Released

答案 3 :(得分:0)

您无法远程分析堆。您可以在服务器上运行visualvm并将x会话导出到本地计算机。您必须在服务器上安装x11,许多服务器都没有。