`
ayufox
  • 浏览: 273299 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

[Java性能剖析]Sun JDK可视化性能剖析工具介绍

    博客分类:
  • JVM
阅读更多

      除了一些基础的工具,随Sun JDK一起发布的还有一些可视化的分析工具,包括JConsole和在JDK6.0.7版本中引入的Visual VM。
      1.JConsole:JConsole可以说是前面介绍的所有功能性JDK工具的一个可视化版本,几乎实现了JVM Manage API中提供的所有的功能。
       1)连接
       JConsole在JDK6中有两种连接方式,一种是使用Attach API连接到本地的进程上,另一种则需要被监控的JVM启动远程JMX Agent,在前面我们已经接触了Attach API的连接方式,这里我们使用远程的连接方式
       首先,需要在被监控的JVM上启动JMX Agent,需要在启动参数中增加如下参数:

-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=7766 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false
(在7766端口上启动JMX Agent,我们当然可以配置认证策略,详细见http://java.sun.com/j2se/1.5.0/docs/guide/management/agent.html )

      使用JConsole连接到JMX Agent上
 
      2)功能

  • 概述

 

  • 内存

 

  • 线程

 

 

  • VM摘要

 

  • MBean

 
      2.Visual VM
      Visual VM是JDK6.07版本后引入的工具,也可以独立下载(https://visualvm.dev.java.net/),虽然远后于JConsole引入,但个人觉得远不如JConsole好用(也许是习惯的缘故),总体上还是比较让人失望的。
     首先看一下总体的功能情况(注意进入tools/plugin,更新一下所有的plugin)
 
      左边是可以连接的JVM,自动检测并显示出来,同时支持远程的连接,通过JMX Agent或jstatd的方式,右边的功能框可以看出其基本功能,除了Sampler和Profiler,其他的功能全部可以在JConsole中看到影子。Sampler是基于定时对线程栈采样的方式来计算性能的,因此准确度不是很高,好处就是完全基于JVM Manage API。Profiler则是基于Java Instrutment技术,非常遗憾的是,只支持本地的CPU和Memory的剖析,可以说没有太多的实用价值。

2
5
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics