[Java性能剖析] TPTP性能剖析介绍

    TPTP(Test & Performance Tool Platform)是Eclipse的又一测试/性能剖析的力作,本篇重点关注远程JVM的性能剖析功能。
    1.我们先看一下TPTP性能剖析的主要结构:
    
    1)对于性能剖析,会有一个ProfileAgent伴随JVM一起启动
    2)对于每台物理服务器,会有一个AgentControler,AgentController负责与ProfileAgent进行通信
    3)客户端TPTP会与AgentControler进行联系,进而获得每个ProfileAgent的剖析信息
    2.安装
    1)如上图所示,使用TPTP进行远程JVM的性能剖析,需要下载ProfileAgent、AgentController和TPTP,可以从下面的下载页面获得相关资源的下载,需要下载TPTP All-in-One和Agent Controller(包含ProfileAgent和Agent Controller),注意版本要一致,否则可能会有问题:http://www.eclipse.org/tptp/home/downloads/
    2)TPTP All-in-One的安装没啥好讲的,解压缩即可
    3)Agent Controller安装稍微复杂一点,以Linux环境为例,首先需要将下载的包解压缩到一个目录(注意,解压缩过程必须在Linux环境下做,在其他环境解压缩完后再拷贝过去是会有问题的),解压缩完毕之后需要配置一下环境变量
    vi /etc/profile,设置一下如下的环境变量(假设这里TPTP解压缩到/home/ayufox/study/tools/tptp目录下)

export JAVA_HOME=/usr/java/jdk1.6.0_19
export TPTP_AC_HOME=/home/ayufox/study/tools/tptp
export JAVA_PROFILER_HOME=$TPTP_AC_HOME/plugins/org.eclipse.tptp.javaprofiler
export PATH=$JAVA_HOME/bin:$TPTP_AC_HOME/bin:$PATH
export LD_LIBRARY_PATH=$TPTP_AC_HOME/lib:$TPTP_AC_HOME/bin:$JAVA_PROFILER_HOME:$LD_LIBRARY_PATH

    source /etc/profile试环境变量设置生效(或者重新登陆)
    在windows环境设置中,需要将$PATH设置部分和$LD_LIBRARY_PATH设置部分加入到path中即可
    4)在被剖析的JVM的启动参数中加入如下部分

-agentlib:JPIBootLoader=JPIAgent:server=enabled;CGProf

    server有enabled、standalone、controlled三种可选配置,具体什么意思可以参见:http://www.eclipse.org/tptp/platform/documents/tutorials/jvmti/Java_Application_Profiling_using_TPTP-v2.0.html 。比较有用的选项就是enabled
    最后部分表示设置的剖析器,有如下三种:

  • CGProf:执行时间剖析
  • HeapProf:堆内存剖析
  • ThreadProf:线程剖析

    遗憾的是,一次只能选择其中的一种类型
    5)启动AgentController
    在启动AgentController之前,先进入AgentController安装目录下的bin目录,运行SetConfig.sh进行设置,提醒非常完备,这里不做介绍。然后再运行ACStart.sh启动AgentController。一些细节问题可以参见:http://www.eclipse.org/tptp/home/downloads/installguide/agentcontroller_33/linux_ia32/getting_started.html
    6)准备完毕,我们可以使用TPTP连接到AgentController上
    在TPTP中打开Profile Configuration,新建一个Attach to Agent实例,新增远程AgentController所在的服务器的IP

    进入Agent Tab,Refresh,选中Java Profilling,点Profile开始进行剖析
 
   3.TPTP提供了什么功能呢?
   1) CGProf:执行时间剖析
    
   2)HeapProf:堆内存剖析


   3)ThreadProf:线程剖析

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值