您的位置:首页 > 编程语言 > Java开发

jdk自带检测内存,cpu,线程 的工具――jvisualvm

2013-12-06 13:34 489 查看
一个很强大的免费工具:JDK6自带的jvisualvm。其实还有个自带工具 jconsole 这里不多说, 用法跟 jvisualvm 差不多。 都是输入命令启动
这个东西我以前听过说,但一直没有用过。看到它提供的截图中可以看到各线程的运行状态,所以准备试一下。这里记录一下使用过程。1。启动在命令行输入jvisualvm。如果jdk安装正确的话(6.x以上版本),就会看到如下的一个窗口:


看起来相当简洁,不像是很强大的样子。2。运行一个Java程序IncTestN,jvisualvm会自动找到它


3.右键点击它,”打开”



可以看到它有很多标签页,可以让我们监测程序的各种数据。默认没有这么多,我其实安装了一些jvisualvm的插件。4。查看jvm参数及系统属性


5。查看cpu、内存、类、线程的统计数据



注意,右边第一个还可以查看PermGen。对于scala程序,因为它产生了大量的类定义,所以PermGen有可能会不足,可通过该选项查看PermGen,适当调整:



可以看到,对于本程序来说,PermGen还是比较充分的,无须调整。6。查看各线程运行情况这个是重点,我们需要知道各线程的运行情况,特别是否被synchronized阻塞了。


注意右下角,有四个状态说明,分别是:运行(Running):我们最喜欢的状态。说明该线程正在执行代码,没有问题。

休眠(Sleeping):调用了Thread.sleep后的状态,说明线程正停在某个Thread.sleep处

等待(Wait):手动调用了wait方法,或者某些IO操作,在阻塞中等待数据。

监视(Monitor):这里就是我想找的问题了。它表示线程想执行一段synchronized中的代码,但是发现已经有其它线程正在执行,自己被block了,只能无奈地等待。如果这种状态多,说明程序需要好好优化。

从上面的这个图可以看到,下面多个线程都处于”监视”状态。多个线程都卡在了独木桥的一头过不去,干不了活干着急呢。当然这个程序是我专门设计成这样的,存在着严重的性能问题,需要好好优化。7。查看各线程的统计数据如果我们需要一些统计数据,比如某个线程总共运行了多少时间,”运行”状态有多久(或百分比),休眠、等待、监视有多久,则需要用到”表”这一页。


从中可以看到这个悲催的程序,几分所有的时间都用在了synchronized的阻塞上了。只有百分之零点几的时间在运行中,效率可真低啊。还可以使用图表方式来看这些数据,得到更直观的体验:


8。查看各方法的运行时间想不想程序中到底是哪些方法一直在运行?可使用”抽样器”功能:
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: