posts - 145,comments - 23,views - 73万

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

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

	执行: btrace 9284 BtraceTest.java

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

posted on   梦中彩虹  阅读(2685)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示