距离上次介绍Jconsole已经时隔两周了,这期间由于工作中要用go来做一个新项目,所以精力都用在入门go上了,不过发现go语言用起来真的挺不错的,比python感觉还好点,大家没事可以了解下。
    言归正传,VisualVM和Jconsole同是图形化的jvm监控和分析工具,两者在一些基本功能上的使用大同小异,比如内存、线程、jvm环境参数等,但是相对而言VisualVM的功能要稍强于Jconsole,相当于加强版的Jconsole。同是visualVM的一些高级功能是通过安装插件来拓展,所以更能因需定制。先看下起始页:

由于VisualVM官方已经提供了很完善的使用文档(同样是亲儿子,Jconsole的文档就有点寒掺了,而且VisualVM有一部分竟然有中文版),所以这里就不做详细介绍,只重点看一下的VisualVM两个方面:

  • 插件安装
  • 程序性能分析

一、VisualVM插件安装

这个其实没什么好介绍的,基本上看图就明白了。插件可以进行手工安装,可以再插件中心下载*.nbm,在选项“工具—插件—已下载”中选择安装,但是作为一款便捷的图形化工具,这样做无意有点费事,其实在"工具—插件"中我们可以直接管理已安装插件,并选择下载安装需要的新插件。看图:

可以看到VisualVM提供了很丰富的插件,我们只要选中需要插件,点击安装即可(当然,前提是你待联网了)。好了,就是这么简单。

二、程序性能分析

这里使用我写的一个小的web服务器做示例,介绍和代码见博客(由于之后更新,可能github与介绍有一定出入),可运行包见下载(目前win下可直接通过bin下start.bat启动,由于start.sh是拷之前一个项目的,暂时有些问题,所以linux下就直接java命令启动吧),成功启动后如下:

然后通过VisualVM打开对应进程,可以通过概述、监视、线程、visaul GC查看程序当前jvm参数、内存、cpu、线程和gc的各项情况。我们这里重点关注一下VisualVM提供的性能分析工具Profilter,我们直接打开该选项卡,点击CPU将开始收集信息并分析。结果你可能发现当时只有ServerTimerTask.run()一项(也可能会有很多项,这主要由于是实时分析,看你打开时程序在做什么操作,是个web服务器,所以可能有个定时轮询的任务一直在执行,所以至少会有这一项,而且包路径sun.net.httpserver也可能看出这点),为了尽快看到更多调用信息,我们直接在浏览器打开http://localhost:8888/json/show.do (这是测试项目中测试json数据的路径),会发现出现很多调用信息,截图如下:

可以看到cpu耗时最多的是log,这其实也好理解,由于写代码的时候几乎在每个操作内都打了log,而且还有写外部log文件的操作,所以耗时较长,从这点看这个程序应该选择一些关键地方打log,比如在调度模块的起止地方、异常处理模块里边,而没有必要每个操作都输出信息。而第二个则是Exchange.run(),这个更好理解了,由于程序在http请求接收和相应处理上目前使用jdk的httpserver模块,而Exchange正是对这些操作的封装,是web服务器的核心模块,cpu耗时多是自然的。第三名如果你看过代码就明白了,responseToClient方法是将响应数据写入响应流。其他的就不一一分析了,其实了解了功能和代码就很容易看明白。
    我们再来看下调用次数,按照调用次数排序后,会发现ServerTimerTask.run()调用次数远远高于其他方法,这个根据前边说的应该都明白,就不解释了。同时可以看一下responseToClient()的调用次数,会发现和你网页上请求的次数一致。
    最后我们来看一个典型的例子,我们在方法名过滤器输入SessionCleanTask,结果如下:

    如果你耐着心观察,会发现没两分钟调用次数会+1,其实这个方法是个timeTask,作用就是每两分钟清理一次过期的session(咱这程序麻雀虽小,但还算五脏俱全吧^_^)。

下边看下内存的分析,该项里边可以看到每个对象实时的内存占用、对象数和年代数,具体分析思路其实和cpu大同小异, 就不再细说了,看图:

好了,VisualVM介绍到此结束,其实其功能要比这强的多,比如dump文件分析和BTrace动态日志追踪(通过热插入日志代码分析程序)等,感兴趣就自行分析吧,这里还有一篇介绍VisualVM可供参考
    之后将考虑开始写类文件结构和类加载部分,不过由于工作忙起来了,所以速度可能慢些,尽量一周至少一篇吧。不费话了,没衣服穿了,出去买件衣服,不然明天木法上班了T_T。

JVM学习总结五(番外)——VisualVM的更多相关文章

  1. JVM学习总结五(番外)——JConsole

    之前本来打算结合自己写的小程序来介绍JConsole和VirtualVM的使用的,但是发现很难通过一个程序把所有的场景都体现出来,所以还是决定用书中的典型小例子来讲更加清晰. 一.JConsole的基 ...

  2. java之jvm学习笔记五(实践写自己的类装载器)

    java之jvm学习笔记五(实践写自己的类装载器) 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和第四节我们一直在强调一句话,类 ...

  3. Netty学习笔记(番外篇) - ChannelHandler、ChannelPipeline和ChannelHandlerContext的联系

    这一篇是 ChannelHandler 和 ChannelPipeline 的番外篇,主要从源码的角度来学习 ChannelHandler.ChannelHandler 和 ChannelPipeli ...

  4. JVM学习总结五——性能监控及故障处理工具

    之前扯了四篇理论,这一篇终于可以动动手了.本篇我们将介绍JVM常用的一些工具,这些工具将是我们监控JVM状态.处理故障和调优分析的利器. 不过在开始之前,我还是要先车扯两句:工具终归只是帮助我们我们处 ...

  5. JVM学习(五)对象的引用类型

    一.引言 前面我们学习了JVM的垃圾回收机制,我们知道了垃圾回收是JVM的自发行为:虽然我们可以通过System.gc() 或Runtime.getRuntime().gc()进行显式调用垃圾回收 , ...

  6. java jvm学习笔记五(实践自己写的类装载器)

     欢迎装载请说明出处:http://blog.csdn.net/yfqnihao 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和 ...

  7. JVM学习笔记五:虚拟机类加载机制

    类加载生命周期 类加载生命周期:加载.验证.准备.解析.初始化.使用.卸载 类加载或初始化过程什么时候开始? 遇到new.getstatic.putstatic或invokestatic这4条字节码指 ...

  8. JVM学习(五) -执行子系统

    虚拟机和物理机的区别.两种都有代码执行能力.物理机的执行引擎是建立在处理器.硬件.指令集和操作系统上.而虚拟机的执行引擎是有自己实现的.因此可以自行的制定指令集和执行引擎的结构关系. 个人理解:分为三 ...

  9. JVM学习十五 - (复习)类加载的时机、类加载过程、类加载器

    一.类加载的时机 类的生命周期 类从被加载到虚拟机内存开始,到卸载出内存为止,它的整个生命周期包括以下 7 个阶段: 加载 验证 准备 解析 初始化 使用 卸载 验证.准备.解析 3 个阶段统称为连接 ...

随机推荐

  1. OSGI.NET 插件无法启动之情景一

    关于osgi.net 的使用网上也有不少的资料,最近在使用osgi.net  开发插件的时候,遇到了这样的bug,造成插件甚至整个项目都无法启动,异常的具体消息如下: Could not find a ...

  2. TypeError: validator.settings[("on" + event.type)].call is not a function

    昨天遇到此错误信息,下面是调试后正确的代码: $("#inputForm").validate({//inputForm是对应的表单的id onkeyup:false, onfoc ...

  3. 农村的“无为教育” (FW)

    农村的“无为教育” 发布时间:2009年11月5日 11时33分 “以孩子影响孩子”,准确地说,是以偏远乡村贫困家庭的进取孩子,影响城市有相当收入的“问题孩子”.有两点值得注意,一是农村孩子影响城市孩 ...

  4. 洛谷P2724 联系 Contact

    P2724 联系 Contact 17通过 86提交 题目提供者该用户不存在 标签 难度普及/提高- 提交  讨论  题解 最新讨论 暂时没有讨论 题目背景 奶牛们开始对用射电望远镜扫描牧场外的宇宙感 ...

  5. android大项目运行中出现问题汇总

    Android 项目中,特别是当项目文件和规模达到一定的程度后,会引发一些平常不常见的问题. 下面对遇到的一些问题做一个汇总和总结. scenario 1: 在项目中,我们采用了chromimum内核 ...

  6. Linux平台下Lotus Domino服务器部署案例

    Linux平台下Lotus Domino服务器部署案例 几年前我写了篇<RHAS2.1下安装中文LotusDominoR6.5图解>这篇文档被多个大型网站转载,曾帮助过很多公司系统管理员部 ...

  7. 【MySQL】MySQL索引背后的之使用策略及优化【转】

    转自:http://database.ctocio.com.cn/353/11664853.shtml 另外很不错的对于索引及索引优化的文章: http://www.cnblogs.com/magia ...

  8. Windows phone 8 学习笔记(2) 数据文件操作(转)

    Windows phone 8 应用用于数据文件存储访问的位置仅仅限于安装文件夹.本地文件夹(独立存储空间).媒体库和SD卡四个地方.本节主要讲解它们的用法以及相关限制性.另外包括本地数据库的使用方式 ...

  9. C# 委托:把方法组合到一个数组中使用

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...

  10. javaSE第十一天

    第十一天    63 1:Eclipse的概述使用(掌握)    63 2:API的概述(了解)    63 3:Object类(掌握)    63       第十一天 1:Eclipse的概述使用 ...