如何用TPTP来调试你的程序

发表于:2008-3-13 16:18

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:未知    来源:网络转载

  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

《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号