btrace进行性能测试

使用BTrace 做性能测试

在官网https://kenai.com/projects/btrace/downloads/directory/releases/release-1.2.4

下载对应的jar包

 

测试时后,将btrace测试类和被测试类放在同一个机器上

 

将btrace测试类写好,放在btrace解压的bin目录下

调用如下命令进行测试

 

sh btrace pid BtraceTest.java

 

pid可通过jps命令来查看,默认端口是2020端口,如果被测试类有多个进程,则端口号累加

2021  2022   2023 ……

 sh bin/btrace -p 2021  41479 bin/App.java > exeTime.txt

Btrace类

import com.sun.btrace.annotations.BTrace;

import com.sun.btrace.annotations.Kind;

import com.sun.btrace.annotations.Location;

import com.sun.btrace.annotations.OnMethod;

import com.sun.btrace.annotations.ProbeClassName;

import com.sun.btrace.annotations.ProbeMethodName;

import com.sun.btrace.annotations.TLS;

 

import static com.sun.btrace.BTraceUtils.*;

 

@BTrace

public class BtraceTest {

 

         @TLS

    private static long startTime=0;

    @OnMethod(clazz = "/*/", method = "/.*/", location = @Location(value=Kind.ENTRY, clazz="/.*/", method="/.*/"))

    public static void startMethod() {

       startTime =timeMillis();

    }

   

    @OnMethod(clazz = "/*/", method = "/.*/", location = @Location(value=Kind.RETURN, clazz="/.*/", method="/.*/"))

    public static void endMethod(@ProbeClassName String className, @ProbeMethodName String methodName) {

        println(concat("threadId:", str(threadId(currentThread()))));

        println(strcat("className:", className)); 

        println(strcat("methodName:", methodName));

        println(strcat("exeTime:", str(timeMillis()-startTime))); 

 

    }

   

    @OnMethod(clazz = "//", method = "sendHttpRequest", location = @Location(value=Kind.RETURN, clazz="/.*/", method="/.*/"))

    public static void endMethod2(@ProbeClassName String className, @ProbeMethodName String methodName) {

             println("CommonBizImpl----sendHttpRequest----------");

             //System.out.println("CommonBizImpl----sendHttpRequest----------");

        println(concat("threadId:", str(threadId(currentThread()))));

        println(strcat("className:", className)); 

        println(strcat("methodName:", methodName));

        println(strcat("exeTime:", str(timeMillis()-startTime))); 

 

    }

   

}


以上*为你要监测的类或者方法名,这里注释掉了 


threadId:34746

className:*l

methodName:getCacheByTid

exeTime:4

threadId:34754

className:*

methodName:getCacheByTid

exeTime:4

threadId:34746

className:*

methodName:getCacheByTid

exeTime:4

threadId:34746

className:*

methodName:getCacheByTid

exeTime:3

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值