zoukankan      html  css  js  c++  java
  • 使用Btrace来动态监控方法的参数和返回值

    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:trace-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

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

    	执行: btrace 9284 BtraceTest.java
    

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

  • 相关阅读:
    spring boot打包出现yaml配置文件问题
    spring boot定时器使用异常
    常见mysql死锁案例行死锁与表死锁
    数据库三范式
    【leetcode】26. 删除排序数组中的重复项
    【数据结构与算法】10.2 二叉排序树
    【设计模式】5、适配器设计模式之对象适配器
    【数据结构与算法】10.1、赫夫曼树代码实现
    【设计模式】4、建造者模型以及Stringbuilder源码分析
    【设计模式】2、工厂模式之简单工厂、方法工厂、抽象工厂
  • 原文地址:https://www.cnblogs.com/jiaoyiping/p/6368722.html
Copyright © 2011-2022 走看看