如何利用 JConsole观察分析Java程序的运行.docx

如何利用 JConsole观察分析Java程序的运行.docx

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
如何利用 JConsole观察分析Java程序的运行

如何利用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)无认证连接 (下面的设置表示:连接的端口为8999、无需认证就可以被连接)Java代码 ?-Dcom.sun.management.jmxremote.port=8999-Dcom.sun.management.jmxremote.authenticate=false-Dcom.sun.management.jmxremote.ssl=false-Dcom.sun.management.jmxremote.port=8999 \-Dcom.sun.management.jmxremote.authenticate=false \-Dcom.sun.management.jmxremote.ssl=false?如果考虑到安全因素,需要认证,需要安全连接,也是可以搞定的。参考:/javase/6/docs/technotes/guides/management/agent.html#gdenv四、JConsole如何连接远程机器的JAVA程序(举例说明)1、写一个简单的一直运行的JAVA程序,运行在某台机器上如(81)Java代码 ?java?-cp?.?-Dcom.sun.management.jmxremote.port=8999?-Dcom.sun.managent.jmxremote.authenticate=false?-Dcom.sun.management.jmxremote.ssl=false?JConsoleTest??java -cp . -Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.managent.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false JConsoleTest?2、另外一台机器进行连接可以直接使用命令:Java代码 ?jconsole.exe?192.1680.1818999jconsole.exe 81: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下的参数,然后在这个视图下观察,以得到好的性能。这里贴一下 Java?HotSpot?VM garbage collect

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档