论坛首页 Java企业应用论坛

远程监控JVM--VisualVM

浏览 33799 次
该帖已经被评为良好帖
作者 正文
   发表时间:2009-11-13   最后修改:2009-11-13

  对于使用命令行远程监控jvm太麻烦?那可以试试sun提供的VisualVMjdk1.6自带了,可以到bin目录下找到它。

         什么也不说了,直接运行此exe,打开界面如下:

 



 

(图1

         (上图1左边的数可以看到,VisualVM分为3类,Local它会自动侦测到,并显示出来)

         双击Local下的任一节点,看到右边的变化(有点像JProfiler

 

 



 



 

(图2

         看看Visual GC的界面(Java Heap的使用,一目了然)

 



 

(图3

         再在左边的树形窗口,右键看看(看到了Thread Dump, Heap Dump

 



 

(图4

         Thread Dump很快,马上就可以看到结果

 



 

(图5

         Heap Dump要稍花费一些时间(可以看到当前heap里对象的数量及占用的比例,做OOM很好用)

 



 

(图6

                   双击每一行,可以看到具体的信息

 



 

(图7

 

 

我们再看一下图1,左边的窗口中,第二个节点—Remote,它可以用来操作远程机器。远程机器需要启动一个daemon:jstatd

1、远程机器启动jstatd

      1.1、        首先需要准备一个java.policy文件,保存到如/home/admin/jstatd.java.policy

grant codebase "file:${java.home}/../lib/tools.jar" {

   permission java.security.AllPermission;

};

      1.2、        启动jstatd

jstatd -J-Djava.security.policy=/home/admin/jstatd.java.policy -J-Djava.rmi.server.logCalls=true

      1.3、        同时需要执行一个命令看看(linux需要)

Hostname –i

如果显示是127.0.0.1,则需要修改/etc/hosts文件,去掉对本机名的配置,让本机名解析到它的IP地址,如10.20.131.214

2、连接远程机器

 



 

(8)

3、点击OK,看到会连接到远程机器,并显示出它下面的java进程。

 



 

(图9

      到 这个时候的操作,就和上面Local的描述操作一样了。

 

最后,要注意的地方:

最好使用jdk1.6以上版本,不然visualVM很多功能不能用。

你自己也可以写一个VisualVM插件(基于NetBeans的插件体系),完成特殊的任务。

  • 大小: 82.3 KB
  • 大小: 78.1 KB
  • 大小: 68.1 KB
  • 大小: 73.4 KB
  • 大小: 35.3 KB
  • 大小: 78.7 KB
  • 大小: 94.2 KB
  • 大小: 63.2 KB
  • 大小: 29.9 KB
  • 大小: 3.6 KB
   发表时间:2009-11-13  
没有用过,不懂,成长中
0 请登录后投票
   发表时间:2009-11-13  
刚才看了一下,貌似mac中没有这个阿
0 请登录后投票
   发表时间:2009-11-13  
能跟jprofiler一样定位到每个方法占用的cpu和内存吗?
0 请登录后投票
   发表时间:2009-11-14  
还在用1.5,试下lz的这个工具,目前一直用jconsole.exe

所说的需要1.6版本,是指本地JDK需要1.6?服务器1.5也无所谓吗
0 请登录后投票
   发表时间:2009-11-14  
这个只在jdk1.6才有,而且是在jdk1.6.0_07后才有。
0 请登录后投票
   发表时间:2009-11-14  
虽说是个小技巧,不过 很有用,谢谢分享。
0 请登录后投票
   发表时间:2009-11-14  
好像用到了rmi
0 请登录后投票
   发表时间:2009-11-14  
独立思考 写道
刚才看了一下,貌似mac中没有这个阿

mac上的jvm版本很新的才有,我记得。可以自己去下载的。我在win上下了jdk7就没有,自己去下载的。
0 请登录后投票
   发表时间:2009-11-15   最后修改:2009-11-16
用VisualVM做Profiler还是不错的,基本的数据都能搞定

BTW: 小军的头像很有型
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics