BTrace实战

BTrace在解决现场问题的时候非常有用。

1、概述

1.1下载

https://github.com/btraceio/btrace,最新版本是1.3.9

目前1.3.x系列最低支持JDK1.7,要想使用JDK1.6的话,可以下载http://download.csdn.net/detail/ccscu/9899450

1.2开始使用

使用命令:./btrace pid HelloWorld.java

1.3安全限制

默认不支持for循环等,可以使用-u来突破限制

1.4定义classpath

-cp

1.5输出结果到文件

推荐使用重定向而不是-o

1.6预编译脚本

./btractc HelloWorld.java

2、拦截方法定义

1、构造函数的名称是<init>

@OnMethod(clazz="java.util.Timer", method="<init>")

2、内部类的名称是在类名和内部类之间加上$

@OnMethod(clazz="org.apache.struts2.dispatcher.Dispatcher$Locator", method="getLocation")

3、拦截多个同名的函数,可以定义不同的参数列表区分

3、拦截时机

3.1Kind.ENTRY和Kind.RETURN

[email protected](Kind.RETURN)

默认值就是Kind.ENTRY,如果使用AnyType来定义,必须使用Kind.ENTRY,否则会进入一种特殊的静默模式;

如果想获得返回值或者运行时间,必须使用Kind.RETURN。

3.2Kind.THROW

@OnMethod(clazz = "org.apache.coyote.tomcat5.CoyoteResponse", method = "getWriter", location = @Location(Kind.THROW))

4、获取this、参数和返回值

4.1定义注入

@OnMethod(clazz = "java.util.HashMap", method = "put", location = @Location(Kind.RETURN))
 public static void onPutMap(@Self Object obj, String key, String value, @Return AnyType result)

参数列表要么不定义,要定义就需要完整,否则BTrace无法处理同名函数;

也可以使用AnyType或者AnyType[]来表示,这个时候必须使用Kind.ENTR,否则会进入一种特殊的静默模式,只要有一个函数打印错了,整个BTrace就什么也打印不出来。

4.2获取对象的属性值

如果是JDK的类

field("java.lang.Thread", "name");

非JDK的类

private static Field response = field(classForName("com.neusoft.unieap.techcomp.ria.action.BaseEntry", contextClassLoader()), "response") ;

Object res = get(response, obj);

这里除了get方法之外,还有getBoolean、getInt等各种基础类型的方法。

5、其他常用API

5.1获取当前线程名称

BTraceUtils.Threads.name(BTraceUtils.currentThread())

5.2获取队形的Hash code

BTraceUtils.identityHashCode(params[1])

5.3获取对象的类名称

BTraceUtils.Reflective.name(BTraceUtils.classOf(obj))

其中BTraceUtils.classOf(obj)返回类,BTraceUtils.Reflective.name返回类名称

在写这篇文章的时候借鉴了以下文章:

1、http://calvin1978.blogcn.com/articles/btrace1.html

江南白衣的文笔一流,他的BTrace的文章架构非常好:我完全模仿了他的结构

2、http://www.bo56.com/btrace示例和资料整理/

学习了如何拿到成员变量的值

3、https://www.gitbook.com/book/json-liu/btrace/details

BTrace的中文使用手册,入门必备

时间: 2024-10-05 06:13:14

BTrace实战的相关文章

Java BTrace实战(1)--BTrace的入门和使用

前言: 对线上的java服务, 往往采用日志进行问题处理和分析. 倘若日志缺乏相关的信息时, 那又该如何处理? 远程调试会影响服务的正常工作, 修改代码重新部署的方案其实时性和灵活性难以保证(线上服务的流程繁琐, 问题追踪的不确定性), 有没有两全的完美方案(不影响正常服务, 又灵活/无侵入性)呢? 答案是有, 它就是人见人爱, 花见花开的神器BTrace. 那BTrace究竟是这么样的神器, 为何它只要998(啊呸..., -_-bbb). 好了, 让我们一步一步的掀起它的红盖头来. 本系列讲

使用jvisualvm.exe 的Btrace插件介绍/使用教程

一.背景        在生产环境中可能经常遇到各种问题,定位问题需要获取程序运行时的数据信息,如方法参数.返回值.全局变量.堆栈信息等.为了获取这些数据信息,我们可以 通过改写代码,增加日志信息的打印,再发布到生产环境.通过这种方式,一方面将增大定位问题的成本和周期,对于紧急问题无法做到及时响应:另一方面重新部 署后环境可能已被破坏,很难重新问题的场景. 二.BTrace功能 BTrace天生就为解决这类问题而来,它可以动态地跟踪java运行程序.通过hotswap技术,动态将跟踪字节码注入到

Java应用调试利器——BTrace教程

http://www.jianshu.com/p/26f19095d396 背景 生产环境中可能出现各种问题,但是这些问题又不是程序error导致的,可能是逻辑性错误,这时候需要获取程序运行时的数据信息,如方法参数.返回值来定位问题,通过传统的增加日志记录的方式非常繁琐,而且需要重启server,代价很大.BTrace应运而生,可以动态地跟踪java运行程序,将跟踪字节码注入到运行类中,对运行代码侵入较小,对性能上的影响可以忽略不计. 配置及用法 去官网下载BTrace,配置环境变量以便在任何路

Btrace使用教程

下载 下载链接:https://github.com/btraceio/btrace/releases/tag/v1.3.9 安装及环境配置 1.下载一个压缩包 2.解压 3.配置环境变量 sudo vi /etc/profile 添加 export BTRACE\_HOME=/home/josonliu/btrace export PATH=$PATH:$BTRACE\_HOME/bin PS:BTRACE\_HOME必须是你解压的路径 4.使配置生效 source /etc/profile

Spring Boot 实战

原文引用https://www.dazhuanlan.com/2019/08/26/5d630071b1ce1/ 打开google 打开springboot资料 Search or jump to- Pull requests Issues Marketplace Explore @shandudu 59 1,084 316 hansonwang99/Spring-Boot-In-Action Code Issues 0 Pull requests 0 Projects 0 Wiki Secur

【机器学习实战】Machine Learning in Action 代码 视频 项目案例

MachineLearning 欢迎任何人参与和完善:一个人可以走的很快,但是一群人却可以走的更远 Machine Learning in Action (机器学习实战) | ApacheCN(apache中文网) 视频每周更新:如果你觉得有价值,请帮忙点 Star[后续组织学习活动:sklearn + tensorflow] ApacheCN - 学习机器学习群[629470233] 第一部分 分类 1.) 机器学习基础 2.) k-近邻算法 3.) 决策树 4.) 基于概率论的分类方法:朴素

下载-深入浅出Netty源码剖析、Netty实战高性能分布式RPC、NIO+Netty5各种RPC架构实战演练三部曲视频教程

下载-深入浅出Netty源码剖析.Netty实战高性能分布式RPC.NIO+Netty5各种RPC架构实战演练三部曲视频教程 第一部分:入浅出Netty源码剖析 第二部分:Netty实战高性能分布式RPC 第三部分:NIO+Netty5各种RPC架构实战演练

C#网络编程技术FastSocket实战项目演练

一.FastSocket课程介绍 .NET框架虽然微软提供了socket通信的类库,但是还有很多事情要自己处理,比如TCP协议需要处理分包.组包.粘包.维护连接列表等,UDP协议需要处理丢包.乱序,而且对于多连接并发,还要自己处理多线程等等.本期分享课程阿笨给大家带来的是来源于github开源Socket通信中间件:FastSocket,目的就是把大家从繁琐的网络编程技术中彻底地解放和释放出来. 阿笨只想安安静静的学习下网络编程技术Socket后,将学习的成果直接灵活的运用到自己的实际项目中去.

下载Java8实战视频教程

1.15套java架构师,高并发,分布式,集群,大型分布式综合项目实战详情:https://my.oschina.net/java168/blog/863547 2.36套精品Java高级课及架构课,亿级流量,P2P金融,第三方支付,设计模式实战,程序调优,系统设计:https://my.oschina.net/java168/blog/1539323 下载Java8实战视频教程