美文网首页
初识Btrace

初识Btrace

作者: 一个神奇的女码农 | 来源:发表于2018-12-05 17:44 被阅读0次

BTrace是sun公司推出的一款Java 动态、安全追踪(监控)工具,可以在不用重启的情况下监控系统运行情况,方便的获取程序运行时的数据信息,如方法参数、返回值、全局变量和堆栈信息等,并且做到最少的侵入,占用最少的系统资源。

由于Btrace会把脚本逻辑直接侵入到运行的代码中,所以在使用上做很多限制:

1、不能创建新对象、新数组。

2、不能抛出或捕获异常

3、所有可调用的Btrace方法必须是static public void类型的,所有可调用的Btrace属性也必须是static类型的

4、不能创建外部类,内部类,嵌套类或本地类

5、不能有同步代码块或同步方法,不能使用synchronized关键字

6、不能循环(while, for ..)

7、不能实现继承与接口

8、不能创建断言与字面量

根据官方声明,不恰当的使用BTrace可能导致JVM崩溃,如在BTrace脚本使用错误的class文件,所以在上生产环境之前,务必在本地充分的验证脚本的正确性。

Btrace可以做什么?

1、接口性能变慢,分析每个方法的耗时情况;

2、当在Map中插入大量数据,分析其扩容情况;

3、分析哪个方法调用了System.gc(),调用栈如何;

4、执行某个方法抛出异常时,分析运行时参数;

BTrace的安装:

在jdk的bin目录下打开jvisualvm.exe

工具 -> 插件 -> BTrace WorkBench 安装就好了

碰到一个小插曲,刚打开的时候可用插件里面没有东西,发现原先的URL失效了.原来是java.net网站已经被Oracle关闭了。visualvm已经迁移到了github上,地址是https://visualvm.github.io/index.html.设置中更新URL就可以下载安装了.

使用BTrace:

话不多说先写个test

public class BtraceTest {

    public static int add(int a,int b){

        return a+b;

    }

    public static void main(String[] args) {

        Scanner scanner = new Scanner(System.in);

        while (scanner.hasNext()) {

            int a = scanner.nextInt();

            int b = scanner.nextInt();

            int c = BtraceTest.add(a, b);

            System.out.println(c);

        }

    }

}

等程序运行test的时候,visualVM就会自动获取到你本地的进程,右键trace application

写下你的脚本

回到test输入程序就可以看到输出日志:

相关文章

  • 初识Btrace

    BTrace是sun公司推出的一款Java 动态、安全追踪(监控)工具,可以在不用重启的情况下监控系统运行情况,方...

  • Btrace学习笔记二

    Btrace拦截行号 被拦截对象(Btrace只能在本地运行) 拦截行号的btrace脚本 运行btrace脚本 ...

  • Btrace UserGuide翻译转载

    原文地址:BTrace用户手册<译> BTrace(https://btrace.dev.java.net/) 是...

  • BTrace:线上问题排查工具

    BTrace简介 GitHub地址:BTrace 下载地址:v1.3.11.3 官方使用教程:Btrace使用教程...

  • btrace-doc

    btrace on github demo 动态获取传入参数 源码 btrace脚本(PrintArgSimple...

  • 使用Btrace进行代码调试

    Btrace简介 Btrace是SUN公司开发的一款动态的Trace工具.Btrace最大的好处是可以自己编写脚本...

  • BTrace:Java 线上问题排查神器

    BTrace 是什么 BTrace 是检查和解决线上的问题的杀器,BTrace 可以通过编写脚本的方式,获取程序执...

  • 用btrace分析线上服务

    部署 btrace1.2.5.1已经部署到集群/home/xjyin/btrace-1.2.5.1 使用方式 基本...

  • btrace

    BTrace的最大好处,是可以通过自己编写的脚本,获取应用的一切调用信息。而不需要不断地修改代码,加入System...

  • Btrace

    入门 拦截方法 拦截时机 拦截this,参数,返回值 获取对象的值 其他 参考 https://github.co...

网友评论

      本文标题:初识Btrace

      本文链接:https://www.haomeiwen.com/subject/lqmwcqtx.html