TPTP全称Test and Performance Tools Platform, 在你的应用正式进入生产系统之前,我们都用用类似的工具来测试我们的系统,找到影响性能的热点(hot spot), 内存益处,io block, 线程等等问题.
使用TPTP, 第一步要做得当然是下载TPTP, 我建议大家下载All-in-One, 这样省去了很多繁琐的plug-in的安装。
TPTP运行有两种模式, 一种是在TPTP的workbench里,一种是通过JVMPI(类似JVMDI, 远程调试的模式), 第一种需要你的项目导入到TPTP里, 第二种模式,你可以很随意的在命令行运行你的程序,通过JVMPI(或者JVMTI)将你的JVM attach 到TPTP, 来进行调试
这里有几个名词你可能比较陌生,JVMPI, JVMDI, JVMTI, 我在前面已经加了链接, 你需要了解一下,值得关注的是JVMPI, JVMDI, 在JDK6里已经不存在了, 所以如果你的应用是基于JDK6的,那么你启动应用的JVMARG是不同的.
在4.4之前,通过JVMPI,你需要下载单独运行的Agent Controller, 但是4.4以后,你不再需要了,agent是自动启动的, 你会发现在你打开了"profiler..."对话框后,系统多了一个ACServer的进程
我很少使用Eclipse 来做开发,所以我的代码都不是Eclipse的项目,所以我重点介绍如何用第二种方式来进行调试
这里需要分JDK, 不同JDK版本,应用的启动方式是不同的,如果你用的是JDK5和JDK5之前的版本, 那么在JVMArgu 里需要加入这样的参数:
-XrunpiAgent:server=enabled
如果是JDK5之后的版本,你必须使用JVMTI的接口, JVMPI已经被删除了(而且你需要添加一个端口10006), 那么你的JVM参数是这样的:
-agentlib:JPIBootLoader=JPIAgent:server=enabled;CGProf
事实上server的模式除了enable 以外,还有另外两种, 一种是standalone, 也是说,这种模式会产生一个log 文件,默认名字是trace.trcxml, 你可以将这个文件导入TPTP来分析
-agentlib:JPIBootLoader=JPIAgent:server=standalone,file=log.trcxml;CGProf
还有一种是Controlled , 具体的用法可以参考手册
在4.3之后,TPTP支持自动发现,只要你刷新Agent, TPTP 会自动发现你的JVM
但是不管哪种模式,你都必须设置环境变量
a) Set TPTP_AC_HOME=>
b) Set JAVA_PROFILER_HOME=%TPTP_AC_HOME%pluginsorg.eclipse.tptp.javaprofiler
c) Set PATH=%JAVA_PROFILER_HOME%;%PATH%;%TPTP_AC_HOME%bin
d) Set PATH=%PATH%;%JAVA_HOME%bin
否则你将得到下面的错误信息:
[java] Error occurred during initialization of VM
[java] Could not find agent library on the library path or in the local dir
ectory: JPIBootLoader