使用Btrace来动态监控方法的参数和返回值

本文介绍btrace工具,一种用于动态跟踪分析运行中的Java应用的方法。通过字节码注入技术,可在不修改源代码的情况下收集应用运行时信息。文章演示了如何设置环境并使用btrace监控一个简单的Java程序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

btrace简介:

btrace是一种动态跟踪分析一个运行中的Java应用程序的工具,它基于java的探针技术动态地向目标应用程序的字节码注入追踪代码(字节码追踪),这些追踪字节码追踪代码使用Java语言表达,也就是BTrace的脚本

btrace在github上的地址:
https://github.com/btraceio/btrace

编译好的软件包的下载地址:
https://github.com/btraceio/btrace/releases

现在(2017年二月)的最新版本是v1.3.9 我们把btrace-bin-1.3.9.zip下载之后解压到磁盘的某个位置然后配置BTRACE_HOME(比如,如果我们将下载下来的文件解压到D盘根目录,就将BTRACE_HOME配置为 D:\btrace-bin-1.3.9),然后将BTRACE_HOME文件夹下的bin目录配置到path里

假设,我们的目标代码如下

    /*
     * Created with Intellij IDEA
     * USER: 焦一平
     * Mail: jiaoyiping@gmail.com
    * Date: 2017/2/5
    * Time: 21:24
    * To change this template use File | Settings | Editor | File and Code Templates
    */

    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;

    public class Demo {
        public static void main(String[] args) throws IOException {
            BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
            System.out.println("please input the first param:");
            String p1 = bufferedReader.readLine();
            System.out.println("please input the first param:");
            String p2 = bufferedReader.readLine();
            getResult(Integer.parseInt(p1), Integer.parseInt(p2));
            System.out.println("press ENTER TO EXIT ...");
            bufferedReader.readLine();
        }

        public static int getResult(int param1, int param2) {
            return param1 * param2;
        }
    }    

监控的代码如下:

import com.sun.btrace.annotations.*;

@BTrace(unsafe = true)
public class BtraceTest {
@OnMethod(clazz = "Demo", method = "getResult", location = @Location(Kind.RETURN))
public static void getParamAndResultByBtrace(int param1, int param2, @Return int result) {

    System.out.println("===========BTrace begin==================");
    System.out.println("the first param:" + param1);
    System.out.println("the second param:" + param2);
    System.out.println("result: " + result);
    System.out.println("===========BTrace end====================");

    }
}

编译并运行目标代码(此时先不要输入需要的参数,因为监控代码还未植入),运行jps获取执行目标代码的进程id,我们得到pid为9284
407044-20170205221721917-470798458.jpg

cd到BtraceTest.java所在的文件夹,

    执行: btrace 9284 BtraceTest.java

此时,监控代码就被注入到了目标代码中,我们输入目标代码需要的两个参数之后,会看到,参数和返回结果被输出了出来:

407044-20170205221750745-486169892.jpg

转载于:https://www.cnblogs.com/jiaoyiping/p/6368722.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值