JVM监控工具VisualVM的使用

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,对象查询语言

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值