欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

JVM监控工具VisualVM的使用

程序员文章站 2024-01-24 11:30:58
...

VisualVM是jvm的可视化监控工具

 

下载地址:http://visualvm.java.net/download.html

 

监控本地jvm很简单,这里不详细说了。

监控远程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和内存性能分析,可以按照包名过滤不需要监控的类

3、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

4、OQL,对象查询语言