远程监控JVM--VisualVM

对于使用命令行远程监控jvm太麻烦?那可以试试sun提供的VisualVM,jdk1.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的描述操作一样了。

 

4、配置远程jvm的jmx启动方式,可以使visualVM提供更多的远程监控功能。

Visualvm目前支持两种remote connection方式,分别是jstatdJMX方式;我看了一下官方的说明文档,如果是针对jboss的监控,官方还是推荐使用JMX的方式监控,因此下面我就讲述一下如何在server端以及客户端配置JMX方式监控的visualvm

1)首先要修改JDKJMX服务的配置文件,以获得相应的权限:

进入$JAVA_HOME所在的根目录的/jre/lib/management子目录下,

a. jmxremote.password.template文件复制为jmxremote.password

b. 调整jmxremote.accessjmxremote.password的权限为只读写,可以使用如下命令

chmod 600 jmxremote.accessjmxremote.password

c. 打开jmxremote.password文件,去掉

# monitorRole QED

# controlRoleR&D

这两行前面的注释符号

2)修改env.sh

打开env.sh文件,并在JVM的启动配置中添加如下信息:

JAVA_OPTS="-Dcom.sun.management.jmxremote.port=1099-Dcom.sun.management.jmxremote.ssl=false-Dcom.sun.management.jmxremote.authenticate=false-Djava.rmi.server.hostname=10.20.150.218 其他配置

这几个配置的说明如下:

-Dcom.sun.management.jmxremote.port:这个是配置远程connection的端口号的,要确定这个端口没有被占用

-Dcom.sun.management.jmxremote.ssl=false-Dcom.sun.management.jmxremote.authenticate=false:这两个是固定配置,是JMX的远程服务权限的

-Djava.rmi.server.hostname:这个是配置serverIP的,要使用serverIP最好在机器上先用hostname –i看一下IP是不是机器本身的IP,如果是127.0.0.1的话要改一下,否则远程的时候连不上,目前我们的server上我已经都改好了



最后,要注意的地方:

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

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


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值