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
location=@Location(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的中文使用手册,入门必备
欢迎查看我之前的博客 http://blog.csdn.net/ccscu
BTrace实战的更多相关文章
- Java BTrace实战(1)--BTrace的入门和使用
前言: 对线上的java服务, 往往采用日志进行问题处理和分析. 倘若日志缺乏相关的信息时, 那又该如何处理? 远程调试会影响服务的正常工作, 修改代码重新部署的方案其实时性和灵活性难以保证(线上服务 ...
- 使用jvisualvm.exe 的Btrace插件介绍/使用教程
一.背景 在生产环境中可能经常遇到各种问题,定位问题需要获取程序运行时的数据信息,如方法参数.返回值.全局变量.堆栈信息等.为了获取这些数据信息,我们可以 通过改写代码,增加日志信息的打 ...
- BTrace使用总结
btracejvisualvmhotswap 一.背景 在生产环境中可能经常遇到各种问题,定位问题需要获取程序运行时的数据信息,如方法参数.返回值.全局变量.堆栈信息等.为了获取这些数 ...
- Btrace使用教程
下载 下载链接:https://github.com/btraceio/btrace/releases/tag/v1.3.9 安装及环境配置 1.下载一个压缩包 2.解压 3.配置环境变量 sudo ...
- Java应用调试利器——BTrace教程
http://www.jianshu.com/p/26f19095d396 背景 生产环境中可能出现各种问题,但是这些问题又不是程序error导致的,可能是逻辑性错误,这时候需要获取程序运行时的数据信 ...
- SSH实战 · 唯唯乐购项目(上)
前台需求分析 一:用户模块 注册 前台JS校验 使用AJAX完成对用户名(邮箱)的异步校验 后台Struts2校验 验证码 发送激活邮件 将用户信息存入到数据库 激活 点击激活邮件中的链接完成激活 根 ...
- GitHub实战系列汇总篇
基础: 1.GitHub实战系列~1.环境部署+创建第一个文件 2015-12-9 http://www.cnblogs.com/dunitian/p/5034624.html 2.GitHub实战系 ...
- MySQL 系列(四)主从复制、备份恢复方案生产环境实战
第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...
- Asp.Net Core 项目实战之权限管理系统(4) 依赖注入、仓储、服务的多项目分层实现
0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...
随机推荐
- Mock相关知识和简单应用
一.moco的简单应用 moco地址:https://github.com/dreamhead/moco api文档地址: https://github.com/dreamhead/moco/blob ...
- python后端面试第五部分:Linux操作系统--长期维护
################## Linux操作系统 ####################### 1,讲一下你常用的Linux/git命令和作用: 2,查看当前进程是用什么命 ...
- JS做深度学习3——数据结构
最近在上海上班了,很久没有写博客了,闲下来继续关注和研究Tensorflow.js 关于深度学习的文章我也已经写了不少,部分早期作品可能包含了不少错误的认识,在后面的博文中会改进或重新审视. 今天聊聊 ...
- php 依赖注入 和 控制反转 php设计模式
https://blog.csdn.net/zyddj123/article/details/82753650 什么是依赖注入?IOC:英文全称:Inversion of Control,中文名称:控 ...
- Java 并发编程面试题
并发编程面试题-内存模型说下内存模型定义为什么要有内存模型为什么要重排序,重排序在什么时候排如何约束重排序规则happens-before什么是顺序一致性CAS 实现的原理,是阻塞还是非阻塞方式?什么 ...
- Java Design Patterns(2)
1.Factory Design pattern 工厂设计模式的优点 (1)工厂设计模式提供了接口而不是实现的代码方法. (2)工厂模式从客户端代码中删除实际实现类的实例化.工厂模式使我们的代码更健壮 ...
- SimpleTrigger的使用
SimpleTrigger的作用 在一个指定时间段内执行一次作业任务或是在指定的时间间隔内多次执行作业任务 使用实例1:距离当前时间4s钟后执行,且执行一次 package com.test.quar ...
- JAVA 截图+tess4j识别
我们先来看看要识别的图片和效果图 效果图: 图片识别需要用到tess4j这个包,下面是下载地址: https://share.weiyun.com/5Hjv13T 我们拿到包以后解压出来,随便你放到哪 ...
- SWUST OJ Gold Nuggets Distribution(0490)
Gold Nuggets Distribution(0490) Time limit(ms): 1000 Memory limit(kb): 65535 Submission: 421 Accepte ...
- git创建/合并分支/删除分支/将修改后的内容同步到GitHub远程仓库
1.创建分支并切换到刚创建的分支(这里创建新的分支来修改README.md的内容然后将创建的分支与master分支合并,最后删除创建的分支) $ git checkout -b 分支名 Switche ...