使用Btrace来动态监控方法的参数和返回值
2017-02-05 22:19
176 查看
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里
假设,我们的目标代码如下
监控的代码如下:
编译并运行目标代码(此时先不要输入需要的参数,因为监控代码还未植入),运行jps获取执行目标代码的进程id,我们得到pid为9284
cd到BtraceTest.java所在的文件夹,
此时,监控代码就被注入到了目标代码中,我们输入目标代码需要的两个参数之后,会看到,参数和返回结果被输出了出来:
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
cd到BtraceTest.java所在的文件夹,
执行: btrace 9284 BtraceTest.java
此时,监控代码就被注入到了目标代码中,我们输入目标代码需要的两个参数之后,会看到,参数和返回结果被输出了出来:
相关文章推荐
- android调用webservice方法,参数或返回值使用服务器端类
- 执行动态 sql 并为 输出参数赋值、sp_executesql 使用方法
- 动态类型调用方法的参数和返回值
- Java调优—Btrace监控Java线程/方法执行参数、执行时间(Windows)
- 系统性能监控系列1:使用JAVA动态代理实现非侵入式的性能测量方法
- Java 带参数带返回值方法的使用
- 使用ExternalInterface调用JS方法-无参数、无返回值!
- Java基础---Java中带参数返回值方法的使用(四十)
- 【java】使用Builder模式,轻松应对动态繁杂的方法参数
- 使用ExternalInterface调用Flex方法-无参数、无返回值!
- Java基础---Java中无参数带返回值方法的使用(三十七)
- 对无返回值、使用Action或Func作为参数、多重载的方法进行单元测试
- 使用<a>标签调用struts2的action、传递动态参数、以及参数中出现加号等特殊字符的处理方法
- 执行动态 sql 并为 输出参数赋值、sp_executesql 使用方法
- 使用ExternalInterface调用Flex方法-传参数、有返回值!
- RhinoMock中无参数方法和无返回值方法的使用
- Java基础---Java中无参数无返回值方法使用(三十六)
- 基础才是重中之重~Emit动态构建方法(参数和返回值)
- 存储过程的参数与返回值使用方法
- Java基础---Java中无参数带返回值方法的使用(三十七)