最近一些朋友谈到了系统性能分析的问题。想分析一个基于Java的系统为什么会慢最好的方法就是使用Profiler. profiler的原理是通过一些驱动和jvm绑定来读取jvm的运行时的情况,得到从类的加载到执行到结束整个过程中时间情况,从而知道到底那些函数的那些方法让你的系统变的很慢。 比较好的开源Profiler工具有Extensible Java Profiler和Eclipse Profiler Plugin 1 Extensible Java Profiler一般用来测试桌面应用程序。 使用以下的方法来运行一个程序 run-enabled application-main-class 程序结束以后会产生一个tracer-output.bin.gz 然后使用EJP Presenter打开这个生成的文件。通过选择自己感兴趣的类,就可以查看到执行过程中各个方法的调用时间了。 2 Eclipse Profiler Plugin通常用于测试WebApplication 以tomcat为例,在catalina.bat中加入以下配置 set _EXECJAVA=%_RUNJAVA% 来绑定jvm,这里的__A__表示启动类 __M__表示不监视的类 然后进入eclipse,在run面板的profiler里面设置要要监视的类,然后启动tomcat,运行的结果可以在下面的面板中看到。包括执行时间,调用率等等。 当遇到性能瓶颈的时候,不妨自己动手测试一下,说不定能发现不少问题。对代码的重构能产生帮助 |
|