5款Java性能分析工具的对比

这是转帖的。

原帖地址:http://blog.jobbole.com/16372/


在给客户的应用程序维护的过程中,我注意到在高负载下的一些性能问题。理论上,增加对应用程序的负载会使性能等比率的下降。然而,我认为性能下降的比率远远高于负载的增加。我也发现,性能可以通过改变应用程序的逻辑来提升,甚至达到极限。为了更详细的了解这一点,我们需要做一些性能分析,自然也要用到一些分析工具。

Java 有许多的性能分析工具,可以帮助我们弄清楚这个问题,但是我们应该使用哪一款工具呢?

为了做出正确的选择,我列出性能分析应满足一些最低要求:

● 必须包括对应用程序的类、方法及时间的监测

● 必须包括对内存的监测

● 必须具有易用性

我配置了一个使用 RESTful 接口的 Spring 应用程序,使用 MongoDB 作为数据存储,还使用 Solr 搜索,并在 Tomcat 服务器上部署。

参考工具:

VisualVM

VisualVM 是一个资源分析工具,一直从 JDK 6 更新到7。它默认内存和 CPU 的监视。它可以告诉你哪个类和方法消耗资源,但它不会显示代码流程。

JProfiler

JProfiler 很容易安装,并且通过向导,你可以选择应用服务器用来运行应用程序。我不得不选择使用 JPofiler 应用服务器的主目录,以及向导生成的一个单独的启动脚本。然后运行服务器。在监听会话的过程中,它会提供了几个选项。它可以记录内存的使用和 CPU 的使用率。在查看 CPU 的使用率同时,可以看到执行路径。这让我看到应用程序大部分时间都花在请求上。我们可以将 IntelliJ 插件安装到 IDE 上,那么运行 JProfiler 会更加便利。比如,可以直接帮我启动 Tomcat。

YourKit

YourKit 是我在另一个项目中偶然发现的一款性能分析工具。它的安装很简单。安装时有一个选项,可以安装一个插件到我的 IDE。安装后,运行应用程序,使用该插件,它会自动连接到 YourKit。它有一个漂亮的用户界面可以查看到内存和 CPU 的监测,同时也可以看到请求的执行路径。

JProbe

我刚开始创建 JProbe 时遇到点困难。安装并不是直接完成,我需要对它进行配置。它采用了类似 JProfiler 一样的设置。它会在你的 Tomcat 目录中生成启动脚本。可以通过脚本启动服务器并监听会话。它的界面包含有按钮和表格,其中可以看到内存的使用,但无法在进程中找到执行路径。

Spring Insight

听到 TC Server 有 Spring Insight 监控界面,于是我兴奋地尝试了一下。安装完成后,并设置成 TC Server 的开发者版,然后部署应用程序在 TC Server 上。我查看 Insight 界面,它可以很好的监视类和方法,并能看到完成这个方法用了多少时间。我还能看到输入参数值,以及返回值。由于我的应用程序是基于 Spring 的,Spring Insight 能够提供非常有用的数据。TC Server 插件在 IDE 上的配置与 Tomcat 的配置类似。SpringSource 工具套件就自带 Spring Insight。

结论

看到这五款性能分析工具,我可以肯定地说,它们都非常不错。如果你有基于 Spring 的应用程序,那么选择 Spring Insight 显然是最佳的。它一直是免费的,但你需要部署你的应用在 TC Server 上。

如果你想监听本地和远程的进程,我会选择 JProfiler 或 YourKit。这两个也可以帮助 Spring Insight 来监测、找到性能瓶颈。

JProfiler 和 YourKit 已经能满足我的上述要求。JProfiler、YourKit 和 Spring Insight 都可以跟踪应用程序的类和方法的流向。JProfiler 和 YourKit 可以显示内存使用情况。虽然 Spring Insight 不可以显示内存使用情况,但它可以很好的显示吞吐量的趋势。这三款性能分析工具功能很清楚,不混乱,而且容易使用。最后,他们都有自己的 IDE 插件。希望本文能帮助你做出正确的选择。


你可能感兴趣的:(5款Java性能分析工具的对比)