VisualVM

VisualVM是jvm的可视化监控工具
下载地址:http://visualvm.java.net/download.html

如果在开发环境,使用什么样的工具是无所谓的,只要能得到结果就好。但是在生产环境里,却不能乱选择,因为这些工具本身就会耗费大量的系统资源,如果在一 个生产服务器压力很大的时候,贸然执行这些工具,可能会造成很意外的情况。最好不要在服务器本机监控,远程监控会比较好一些,但是如果要远程监控,服务器 端的启动脚本要加入一些jvm参数,例如用jconsloe远程监控tomcat或jboss等,都需要设置jvm的jmx参数,如果仅仅只是分析服务器 的内存分配和gc信息,强烈推荐, 先用jmap导出服务器端的jvm的堆dump文件,然后再用jhat,或者jvisualvm,或者eclipse内 存分析器来分析内存状况

监控远程jvm的方法有2种
一、远程服务器启动jstatd守护进程
./jstatd -J-Djava.security.policy=jstatd.all.policy -J-Djava.rmi.server.hostname=192.168.0.50 -J-Djava.rmi.server.logCalls=true -p 1011
 
1、 在JDK/bin下新建一文本文件, 名称 jstatd.all.policy
    内容如下:
    grant codebase "file:${java.home}/../lib/tools.jar" {
       permission java.security.AllPermission;
    };
2、 运行 jstatd -J-Djava.security.policy=jstatd.all.policy
      若需要指定端口, 请使用 -p 1011
      指定守护进程监听的ip(默认是127.0.0.1),请使用-J-Djava.rmi.server.hostname=192.168.0.50
      查看日志,请使用-J-Djava.rmi.server.logCalls=true
      另外注意防火墙,需要使用1011之外的其他端口
3、 在终端启动VisualVM.
 
二、JMX方式
1、JAVA_OPTS="Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmx
remote.ssl=false -Dcom.sun.management.jmxremote.authenticate=true -Djava.rmi.server.hostname=192.168.0.50"
2、鉴权方法
jdk/jre/lib/management/jmxremote.access 定义了2种权限,读写和只读
monitorRole   readonly表示只能监控
controlRole   readwrite表示可以修改jmx的各项配置
可以添加任意用户,如:
admin readwrite
 
jdk/jre/lib/management/jmxremote.password 定义了jmxremote.access中的用户名的密码,如:
admin 111111
 
 
VisaulVM插件
菜单:工具->插件->可用插件(下载)
现在要下载的插件安装即可。几个有用的插件:
1、 Visaul GC,可以参考详细的GC信息和内存使用情况,很详细哦。不过远程访问不支持JMX方式,必须用jstatd方式
2、Visaul MBeans,jmx管理界面,可以管理应用中个所有mbean。如果使用spring,可以通过spring的jmx整合,将bean暴露出来,即可实时的修改各项应用配置。
3、Profile,cpu和内存性能分析,可以按照包名过滤不需要监控的类
4、BTrace,可以在不宕机的情况下调试代码。在visualVM上可以右键选中Trace Applicationg...打开BTrace窗口(只支持本地jvm),下面这个是查看某个方法的执行时间的示例:
/* BTrace Script Template */
import com.sun.btrace.annotations.*;
import static com.sun.btrace.BTraceUtils.*;
@BTrace
public class TracingScript {
    @TLS  
    private static long startTime = 0;
    @OnMethod(clazz="com.aspire.pams3.verify.audit.action.audit.AuditAction", method="getAuditContent")
    public static void startMethod() {
        startTime = timeMillis();
    }
    @OnMethod(clazz="com.aspire.pams3.verify.audit.action.audit.AuditAction", method="getAuditContent", location=@Location(Kind.RETURN))
    public static void endMethod() {
        print(strcat(strcat(name(probeClass()), "."), probeMethod()));
            print(" [");
            print(strcat("Time taken : ", str(timeMillis() - startTime)));
            println("]");
    }
}
如果需要在远程服务器执行,需要下载http://kenai.com/projects/btrace/downloads/directory/releases
将上面的代码保存为TracingScript.java
执行./btrace <pid> TracingScript.java
5、OQL,对象查询语言


你可能感兴趣的:(eclipse,jvm,spring,服务器,jmx,工具)