2009-04-07 87 views
10

我运行JVisualVM(Windows XP,Sun Java 1.6.0.13,32位客户端VM)来监视远程应用程序(Linux,Sun Java 1.6.0.07,64位服务器VM )。开始实际的远程应用程序之前,我在远程机器jstatd上推出使用全访问策略:使用JVisualVM从Java远程应用程序获取堆转储

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提供的工具进行分析。我怎样才能做到这一点?

+0

运行jvisualvm为正在运行的Java进程可能有助于 – rogerdpack 2012-10-02 16:26:26

+0

@rogerdpack好点相同的用户!我导航到这个问题/主题,因为我有同样的问题,http://stackoverflow.com/questions/8799929/visualvm-unable-to-sampler-memory,我认为你的陈述/假设是正确的。当我在我的开发人员PC /服务器上通过NetBeans IDE运行tomcat/tomee时,启用了Sampler> Memory按钮,但在生产服务器上禁用了Sampler> Memory按钮,因为tomcat/tomee作为Windows服务运行, '不'作为系统或本地服务登录到生产服务中。 :( – Howard 2013-04-06 13:55:55

回答

0

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

3

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

6

有办法做到这一点!

  1. rmiregistry中-J-Xbootclasspath/P:$ JAVA_HOME/LIB/SA-jdi.jar(此使用端口1099)
  2. 启动 'jsadebugd',其中应用程序运行在计算机上:jsadebugd &(PID JVM的)
  3. 在远程机器使用以下 JMAP -dump:文件=:1099

  4. 与jHat

以上将在端口启动一个Web应用程序7000

以上所有的工具都JDK 1.6

的一部分

所有最优秀的!

2

自1.3,支持的VisualVM远程堆转储:

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

参见:VisualVM 1.3 Released

相关问题