一、前言
今天收到客户报的一个Bug,登录系统查看发现没有相关日志输出,方法中相关的请求参数及变量都没有打印出来,给排查问题造成很大不便,我们知道解决Java系统疑难杂症有两大利器,其一是tcpdump用于网络抓包分析 、其二是Btrace用于动态跟踪Java代码,tcpdump在 前面一些文章有介绍它的简单使用(用抓包工具分析HTTPS报文)、Btrace其实我也没有实际用过,但因为第一次听说是在2013年多隆(顶级大牛)一堂分享课上,当时有人问他怎么提升自己的技术水平,多隆回答说就是出现问题解决问题,别的也没什么,然后说他排查线上问题用Btrace。
注:提升技术除了在实践中解决各种疑难问题另外最好在一个有挑战的平台。
二、Btrace安装
Btrace是Sun公司一款动态诊断工具,可以在运行中的Java类动态注入trace代码,获取方法的入参、返回值等信息,从而达到调试目的。
在 https://github.com/btraceio/btrace/releases/tag/v2.2.2下载安装包。
然后配置环境变量。
mac .bash_profile
Btrace跟踪命令
btrace <option> <pid> <btrace-script>
三、Btrace实践
1、项目代码
用SpringBoot搭建项目,写一个简单的创建订单方法。
2、Btrace脚本
总共4个方法,分别跟踪方法是否被调用,监控方法耗时,打印方法请求参数(可以打印出基本类型参数,也可以打印出业务对象类型参数)、跟踪某一行代码是否被执行。
跟踪执行的结果如下(用jps先获取Java进程的pid)
注:上面4个方法基本覆盖了一般跟踪的需求。
3、脚本几个注解说明
@Btrace:将该类定义为btrace脚本
@OnMethod:定义拦截的目标类和方法
@Location:定义拦截的时机,类似于AOP
@ProbeClassName: 被拦截的类名
@ProbeMethodName:被拦截的方法名
@Return:方法返回值
AnyType : 通用参数类型,也可以使用具体的类型。