06
Dec
2013

性能测试 工具 TProfile 代码简析

对TProfile (https://github.com/taobao/TProfiler)产生了兴趣,于是就下下来研究了一下:

非常简单小巧,代码质量也很高,最多20个class。其实现的核心原理就是利用javaAgent,在premain函数中使用java.lang.instrument.ClassFileTransformer,对允许采样的类生成org.objectweb.asm.ClassAdapter

1.png

再利用org.objectweb.asm.MethodAdapter的visitXXX 系列(对应功能可到这里查:http://t.cn/SqTMQM),注入采样代码,如下

2.png

注入方法开始时的采样代码

3.png

注入方法结束时的采样代码

visitInsn指的是执行单条指令时需要执行的勾子。

4.png

其实关于这种通过字节码注入方式实现性能监测的方法,IBM还有专门的一篇文档介绍:

http://www.ibm.com/developerworks/cn/java/j-jip/#resources

上一篇:Kiss the Rain 下一篇:觉醒者与成功者

评论列表:

发表评论: