美文网首页
BTrace实战

BTrace实战

作者: 一帅 | 来源:发表于2017-09-01 17:35 被阅读0次

    首先推荐一下【江南白衣】大神对BTrace的文章Btrace入门到熟练小工完全指南。而且在看本篇文章之前最好先看一下这篇文章,不然效果不是很好。

    1.如何在Linux下安装Btrace并使用

    1.1 安装Btrace

    1.下载安装包[下载地址](https://github.com/btraceio/btrace/releases/download/v1.3.8.3-1/btrace-bin-1.3.8.3.tgz)
    2.解压 tar -xvf btrace-bin-1.3.8.3.tgz
    3.导出环境变量
    export BTRACE_HOME=/home/blues/btrace  
    export PATH=$PATH:$BTRACE_HOME/bin  
    

    1.2 编写BTraceDemo

    • 准备测试程序
    import java.util.Random;
    public class BTraceDemo {
        public static void main(String[] args) {
            Calculator calculator = new Calculator();
            Random random = new Random();
            while (true) {
                System.out.println(calculator.add(random.nextInt(10), random.nextInt(10)));
            }
        }
    }
    
    public class Calculator {
        private int c = 1;
    
        public int add(int a, int b) {
            try {
                Thread.sleep(5000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return a + b;
        }
    }
     
    

    我们将测试程序放在btrace_test_demo目录下,然后编译,运行

    root@develop ]# cd btrace_test_demo/
    [root@develop btrace_test_demo]# javac BTraceDemo.java 
    [root@develop btrace_test_demo]# java BTraceDemo
    16
    8
    17
    
    • 获取程序的pid
    [root@develop btrace_test_demo]# jps
    3642 Bootstrap
    32752 BTraceDemo
    
    • 将Btrace脚本绑定到应用程序中
    [root@develop bin]# ./btrace 32752 ../../btrace_script/BTraceTest.java 
    trace1:a=3,b=9,sum=12
    

    OK,这样就算将Btrace的脚本嵌入到我们的应用程序中了。具体的脚本的语法和用法可以参考大神江南白衣的博客

    2.怎样才能方便快捷无误地写出BTrace脚本呢

    2.1 使用VisualVm来写

    如果你使用VisualVm的话,那么也可以使用VisualVm来编写BTrace脚本。不过需要你安装btrace的插件。在VisualVm中安装插件异常的爽,只需要在插件列表中点击一下就可以了。

    如下图(由于我已经安装过了,所以不再【可用插件】列表中,在【已安装】列表中)

    Btrace插件列表.png BTrac已安装列表.png

    安装好BTrace插件之后就可以使用VIsualVm来打开一个java应用程序了。如下打开BTrace脚本的编写界面

    打开Btrace插件界面.png Btrace编写脚本界面.png

    在这里面编写BTrace脚本其实和在记事本上编写脚本差不多。哪为啥要在这写呢?

    • 添加classpath比较方便
    • 将脚本绑定到应用程序方便

    所以如果是单纯地为了写出正确的脚本的话,在这里写是不合适的。下面介绍第二种方式。

    2.2 使用eclipse来写BTrace脚本

    对于一般的程序员而言,使用记事本来写程序不仅效率低下,而且极其容器出错。所以伟大的IDE就诞生了。主流的Java语言的IED有eclipse,idea等。所以如果能在IDE下来写Btrace的脚本的话,出错的可能性就很低了。

    下面就来介绍一下怎么使用eclipse来写Btrace脚本。

    首先我们来看一下BTrace下载的目录的结构。顺便提供一下我使用的Btrace版本的下载地址

    BTrace目录结构

    在【build】下有一个btrace-client.jar的jar包,我们可以将该jar包加到我们的eclipse中来编写,这样我们就可以使用eclipse的提示功能和自动编译的功能了。这样也就不至于交给运维的脚本是有编译和语法问题的。

    btrace-client.jar eclipse下编写Btrace脚本.png

    总结:写脚本一定要在eclispse下编写,保证语法无误。但是如果只是需要在本机运行BTrace的话,那么就可以使用VisualVm的BTrace插件了。但是如果要是在linux下来运行的话,那还是得用命令行来运行。

    相关文章

      网友评论

          本文标题:BTrace实战

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