btrace简单使用
基本安装
在github上btrace项目的release下 下载最新的btrace
https://github.com/btraceio/btrace/releases
解压完后,将btrace的bin目录添加进环境变量
使用方法 btrace <options> <PID> <btrace脚本>
visualvm安装btrace
首先在visualvm中安装btrace插件
菜单栏>工具>插件>可用插件>btrace
安装完成后,如下操作

一个简单的例子
package me.cayun.javalab;
public class {
private static Tmp output(String s, int x) {
|
目标
- 输出该函数的参数
- 输出该函数的执行时间
- 输出该函数的返回值
btrace脚本
import com.sun.btrace.annotations.*; |
解释
- @BTrace 表明这是一个btrace脚本
- @OnMethod 指定方法入口,其中clazz和method参数可以使用正则表达式
- @Location 表示拦截的时机,
- Kind.ENTRY表示在进入方法时执行,默认为ENTRY
- Kind.RETURN表示方法执行后执行
- @Return 表示返回参数,前提location为Kind.RETURN
- @Duration 表示函数执行时间,单位: 纳秒,前提location为Kind.RETURN
- 获取类的某个属性值, get(field(clazz, name), object);
另一种获取函数运行时间的方法
还是刚刚那段Java代码,新的btrace脚本如下
import com.sun.btrace.annotations.*; |
解释
- @TLS 用来将一个脚本变量与一个ThreadLocal变量关联
btrace直接使用项目中的类
public class {
public static AtomicInteger i = new AtomicInteger();
private static void inc(int x) {
|
在第一个示例中,调用项目中的类使用的是反射的方式,但其实btrace也可以直接使用项目的类
目标
- 获取BtraceMain中的i的值
btrace脚本
import com.sun.btrace.annotations.*; |
emm~,只需要在前面import相应的类即可
如果变量为私有变量,仍然需要通过反射的方式获取
btrace关于map的操作
以下代码摘自btrace源码中com.sun.btrace.BTraceUtils函数
public static void printMap(Map map) {
|
其他常见用法
打印调用栈
package me.cayun.javalab;
public class {
private static void gc1() {
|
btrace脚本
import com.sun.btrace.annotations.*; |
查看VM/内存/CPU等信息
可以参考BTraceUtils的源码
https://github.com/btraceio/btrace/blob/master/src/share/classes/com/sun/btrace/BTraceUtils.java
参考
[1] btrace github
[2] BTrace 简明使用手册
[3] BTrace使用
btrace简单使用的更多相关文章
- Java BTrace实战(1)--BTrace的入门和使用
前言: 对线上的java服务, 往往采用日志进行问题处理和分析. 倘若日志缺乏相关的信息时, 那又该如何处理? 远程调试会影响服务的正常工作, 修改代码重新部署的方案其实时性和灵活性难以保证(线上服务 ...
- Btrace入门到熟练小工完全指南
BTrace是神器,每一个需要每天解决线上问题,但完全不用BTrace的Java工程师,都是可疑的. BTrace的最大好处,是可以通过自己编写的脚本,获取应用的一切调用信息.而不需要不断地修改代码, ...
- btrace 实践笔记
btrace简介: btrace 是一个使用在JAVA平台上面的,安全的,动态跟踪工具.它一般用于动态跟踪正在运行的jAVA程序. 使用说明在这里.下载地址在这里. 下载的时候 ...
- btrace拓展工具-java应用性能诊断优化利器
Btrace是一个实时监控工具,可以无需修改应用代码(事实上它修改了字节码),来达到不可告人的秘密!这是性能调优和诊断的利器! 它可以获取应用程序代码的执行时间,他可以让你无需修改代码,帮你做时间的打 ...
- Btrace是一个实时监控工具
http://blog.csdn.net/gzh0222/article/details/9731031 Btrace是一个实时监控工具,可以无需修改应用代码(事实上它修改了字节码),来达到不可告人的 ...
- Btrace
http://www.iteye.com/topic/1005918 背景 周五下班回家,在公司班车上觉得无聊,看了下btrace的源码(自己反编译). 一些关于btrace的基本内容,可以看下我早起 ...
- BTrace : Java 线上问题排查神器
BTrace 是什么 BTrace 是检查和解决线上的问题的杀器,BTrace 可以通过编写脚本的方式,获取程序执行过程中的一切信息,并且,注意了,不用重启服务,是的,不用重启服务.写好脚本,直接用命 ...
- Btrace官方教程-中文版
教程英文版来源:https://github.com/btraceio/btrace/blob/master/docs/usersguide.html BTrace用户指南 BTrace是一种安全,动 ...
- BTrace使用小结
简介 BTrace是一个安全的JVM动态追踪工具,最初为原Sun公司Kenai项目下面的一个子项目. 典型的使用场景是,“我要查个问题,可那个方法没有打印入口参数和返回结果日志”,“我想看某个方法的执 ...
随机推荐
- 单机版solr的搭建
1.1. Solr的环境 Solr是java开发. 需要安装jdk. 安装环境Linux. 需要安装Tomcat. 1.2. 搭建步骤 第一步:把solr 的压缩包上传到Linux系统 第二步:解压s ...
- 03 Mybatis:05.使用Mybatis完成CRUD
mybatis框架:共四天 明确:我们在实际开发中,都是越简便越好,所以都是采用不写dao实现类的方式.不管使用XML还是注解配置. 第二天:mybatis基本使用 mybatis的单表crud操作 ...
- 记录华为、魅族手机无法打印 Log 日志的问题
http://yifeng.studio/2017/02/26/android-meizu-huawei-not-log/ 实测 MEIZU PRO 6 :打开[设置]中的[开发者选项],页面底部找到 ...
- day63-html-列表,表格,标签的嵌套规则
1.列表 1.无序列表 <ul type="disc"> <li>a</li> <li>b</li> </ul&g ...
- SaltStack中状态间关系unless、onlyif、require、require_in、watch、watch_in
1.unless 检查的命令,仅当unless选项指向的命令返回值为false时才执行name定义的命令 cmd.run: {% "] %} - name: 'nohup sh /alida ...
- java实现图片和pdf添加铺满文字水印
依赖jar包 <!-- pdf start --> <dependency> <groupId>com.itextpdf</groupId> <a ...
- [CTSC2008]祭祀(二分图匹配)
没有SPJ时显然是不需要输出方案的.不需要输出方案很好做,先把边扩展(因为会往下流),然后求最大独立集,最大独立集=n-最小点覆盖,因为其是最大独立集的补集.如何求最小点覆盖呢?毕竟我写过最大权闭合子 ...
- UEFI boot: how does that actually work, then?
原文地址:https://www.happyassassin.net/2014/01/25/uefi-boot-how-does-that-actually-work-then/ 翻译:https:/ ...
- 实测两款 GitHub 开源抢票插件,所有坑都帮你踩过了
如果你对自己手速和市面上的各种 “加速包” 都没什么信心的话,不妨试试用程序员的手段抢票? 况且,[12306 官方宣布屏蔽了一大批付费抢票软件],这也意味着你即使给这些软件付了会员费,也依旧抢不到票 ...
- Linux基础篇五:文件操作篇(三剑客)
cut截取字段: -d 指定分割符 -f 指定第几列 例题1: echo "i am dusonglin ,my qq is 380343680 " >dusongl ...