JConsole之Java性能分析器使用

一、JConsole是什么
    从Java 5开始 引入了 JConsole。JConsole 是一个内置 Java 性能分析器,可以从命令行或在 GUI shell 中运行。您可以轻松地使用 JConsole(或者,它更高端的 “近亲” VisualVM )来监控 Java 应用程序性能和跟踪 Java 中的代码。

二、如何启动JConsole
如果是从命令行启动,使 JDK 在 PATH 上,运行 jconsole 即可。
如果从 GUI shell 启动,找到 JDK 安装路径,打开 bin 文件夹,双击 jconsole 。
如下图所示:

    当分析工具弹出时(取决于正在运行的 Java 版本以及正在运行的 Java 程序数量),可能会出现一个对话框,要求输入一个进程的 URL 来连接,也可能列出许多不同的本地 Java 进程(有时包含 JConsole 进程本身)来连接。如图所示:

想分析那个程序就双击那个进程。

三、如何设置JAVA程序运行时可以被JConsolse连接分析
本地程序(相对于开启JConsole的计算机),无需设置任何参数就可以被本地开启的JConsole连接(Java SE 6开始无需设置,之前还是需要设置运行时参数 -Dcom.sun.management.jmxremote )
四、JConsole如何连接远程机器的JAVA程序(举例说明)
可以直接使用命令:

Java代码  

jconsole.exe 192.168.0.181:8999  


 也可以在已经打开的JConsole界面操作 连接->新建连接->选择远程进程->输入远程主机IP和端口号->点击“连接”,如图:

性能分析

进入视图后包括这六个标签:

  • 概述: Displays overview information about the Java VM and monitored values.
  • 内存: 显示内存使用信息
  • 线程: 显示线程使用信息
  • 类: 显示类装载信息
  • *VM摘要:*显示java VM信息
  • MBeans: 显示 MBeans.

上图描述有我们需要的信息,同时点击右键可以保存数据到CSV文件。

内存


内存通常需要我们查看,参看堆内存,非堆内存,内存池的状况总体内存的分配和使用情况以及不同的GC进行垃圾回收的次数和时间。可以手动进行GC查看内存变化。在分析JAVA内存问题进行调优时候非常有用,你要学习JVM内存模型,之后会发现这里的每个值都具有意义。 GC的算法和参数对性能有显著的影响,注意垃圾回收次数、时间、以及partial GC和full GC,调整所使用的不同GC和以及各个GC下的参数,然后在这个视图下观察,以得到好的性能。

除了上面的内存之外,还有线程、类、VM、MBean等这些,都可以根据需要来查看。

猜你喜欢

转载自blog.csdn.net/yuyecsdn/article/details/91410786