VisualVM远程监控

原文:http://licg1234.blog.163.com/blog/static/13908233320102103112298/

对上面文章做了些修正

在服务端启动rmi命令如下:
jstatd -J-Djava.security.policy=/root/jdk1.6.0_21/bin/jstatd.all.policy -J-Djava.rmi.server.logCalls=true

 

其中,红色字体表示jstatd.all.policy文件 路径。

 

还需要注意,hostname改为实际IP。

 

下面为修正后的全文。

 

 

VisualVM是集成了多个JDK命令工具的一个可视化工具,它主要用来监控JVM的运行情况,可以用它来查看和浏览Heap Dump、Thread Dump、内存对象实例情况、GC执行情况、CPU消耗以及类的装载情况。

在JDK Update7之后,VisualVM作为JDK的一部分发布,但同时VisualVM也发布独立的版本。VisualVM必须运行在JDK1.6以上的VM环境下,但可以用它来监控JDK1.4以上的JVM。

下载地址:https://visualvm.dev.java.net/files/documents/7163/144406/visualvm_12.zip

 

一,监控本机JVM

如果要监控本机的JVM运行情况,只要打开VisualVM(在jdk的bin目录下),JVM会自动被添加到VisualVM中进行监控

visualVM1

如上图,VisualVM本身也是一个Java应用程序,因此它自己监控自己JVM的运行情况,只要双击Local –< VisaulVM,右边就可以进行各项指标的浏览。

visualVM2

注:读者看到的标签可能会随着安装的插件不同而有所区别,VisualVM的插件可以通过Tools –<  Plugins 来安装

 

二,监控远程JVM

VisualVM监控远程JVM是通过RMI服务器来实现的,因此需要在被监控的远程服务器上启动RMI服务

1,启动RMI服务

在需要被监控的服务器上面,通过jstatd 来启动RMI服务

首先,配置java安全访问,将如下的代码存为文件 jstatd .all.policy:

Java代码

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

然后通过如下的命令启动RMI服务:

 

linux命令行代码:

  1. jstatd -J-Djava.security.policy=/root/jdk1.6.0_21/bin/jstatd.all.policy -J-Djava.rmi.server.logCalls=true

其中,红色字体表示jstatd.all.policy 文件 路径,这里将其放置在了jdk/bin下。


   注意,如果服务器端是linux系统,还需要注意,hostname改为实际IP。

 

上面启动的RMI服务的端口是1099,如果需要以其它端口启动RMI服务,请查看官方文档:http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jstatd .html

2,启动VisualVM,添加远程主机

右键单击Remote,选择Add Remote Host,输入远程主机的IP地址,不需要端口号。

visualVM3

如果远程服务器启动了RMI服务,VisualVM会自动显示主机上面的JVM

visualVM4

关于VisualVM连接远程JVM的错误,请查看Troubleshooting connection problems in JConsole 一 文,此文总结了连接时会遇到的各种问题,我开始通过VisualVM连接虚拟机中的JVM,总是 报:java.net.ConnectException: Connection refused: connect 错误,也是通过文章中所描述的关于通过NAT访问JVM问题解决的。

 

你可能感兴趣的:(java,jstatd)