前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JVM系列十(虚拟机性能监控神器 - BTrace).

JVM系列十(虚拟机性能监控神器 - BTrace).

作者头像
JMCui
发布2020-04-12 20:31:19
2K0
发布2020-04-12 20:31:19
举报
文章被收录于专栏:JMCui

BTrace 是什么?

BTrace 是一个动态安全的 Java 追踪工具,它通过向运行中的 Java 程序植入字节码文件,来对运行中的 Java 程序热更新,方便的获取程序运行时的数据信息,并且,保证自己的消耗特别小,大部分情况下不会影响 Java 程序的性能。

BTrace 能干什么?

相信每一位开发都或多或少的干过这档子事:为了解决线上的一个 bug,不得不在代码中打印下入参、出参数据,然后再重启服务器,观察日志。BTrace 的出现就是为了解决这类事宜,BTrace 的最大好处,是可以通过自己编写的脚本,获取应用的一切调用信息,而不需要不断的修改代码,然后重启应用。

以下是 BTrace 的一些典型应用场景:

  • 服务慢,能找出慢在哪一步,哪个函数里么?
  • 谁调用了System.gc(),调用栈如何?
  • 谁构造了一个超大的 ArrayList?
  • 什么样的入参或对象属性,导致抛出了这个异常?或进入了这个处理分支?

BTrace 快速开始

下载最新的 BTrace releases 版本:https://github.com/btraceio/btrace/releases

解压文件夹,在 <BTRACE_HOME>/bin 目录下主要有两个命令:一个是 btrace,一个是 btracec。

btrace

代码语言:javascript
复制
BTRACE_HOME/bin/btrace PID <trace_script>

btrace 将通过 JVM Attach API 连接到 的 java 应用程序,然后把脚本绑定到应用进程,进行 AOP 式的代码植入。

btracec

代码语言:javascript
复制
BTRACE_HOME/bin/btracec <trace_script>

类似于 javac,btracec 命令是用来预编译脚本的,以此校验脚本语法的正确性,要不然等运行到线上才发现写错就尴尬了。

BTrace 脚本

写到这里,唯一能阻碍我们继续下去的,就是怎么写 BTrace 脚本了。

首先,推荐在集成工具(IDEA、Eclipse)中编写 BTrace 脚本,引入 BTrace 的依赖:

代码语言:javascript
复制
        <dependency>
            <groupId>com.sun.tools.btrace</groupId>
            <artifactId>btrace-agent</artifactId>
            <version>1.2.3</version>
            <type>jar</type>
            <scope>system</scope>
            <systemPath>D:\btace\libs\btrace-agent.jar</systemPath>
        </dependency>
        <dependency>
            <groupId>com.sun.tools.btrace</groupId>
            <artifactId>btrace-boot</artifactId>
            <version>1.2.3</version>
            <type>jar</type>
            <scope>system</scope>
            <systemPath>D:\btace\libs\btrace-boot.jar</systemPath>
        </dependency>
        <dependency>
            <groupId>com.sun.tools.btrace</groupId>
            <artifactId>btrace-client</artifactId>
            <version>1.2.3</version>
            <type>jar</type>
            <scope>system</scope>
            <systemPath>D:\btace\libs\btrace-client.jar</systemPath>
        </dependency>

先来看一个简单的 Demo 示例:

代码语言:javascript
复制
@BTrace//表示这是一个BTrace跟踪脚本
public class Hello {

    @OnMethod(clazz = "org.jvm.demo.chapter4.btrace.BtraceCase", // 全类名
            method = "add", // 方法名
            location = @Location(Kind.RETURN) // 表示跟踪某个类的某个方法,位置为方法返回处
    )
    public static void run(@Self Object self, int a, int b, // 入参,按顺序定义
                           @Return int result, // 出参
                           @Duration long time // 方法耗时
    ) {
        BTraceUtils.print("打印入参, a = " + a + ",b=" + b);
        BTraceUtils.print("打印出参, result = " + result);
        BTraceUtils.print("打印耗时,time = " + time);
    }
}
代码语言:javascript
复制
btrace.bat 4284 src/main/java/org/jvm/demo/chapter4/btrace/Hello.java

BTrace 主要有两类注解需要学习,一类是探测方法的注解,像上面的 @OnMethod 注解,类似的还有 @OnTimer、@OnError、@OnExit、@OnEvent、@OnLowMemory、@OnProbe 等等;另一类是探测方法参数的注解,像上面的 @Return、@Duration、@Self,类似的还有 @ProbeMethodName、@ProbeClassName、@TargetInstance、@TargetMethodOrField 等等

本文不过分说明 BTrace 的语法,私以为平常遇到什么样的业务场景,边学边用就是了,以下是官方的一些 BTrace 资料:

由于 BTrace 的安全和性能考虑,一般情况下不允许在探查方法中调用 BTraceUtils 以外的其它方法,但可使用 unsafe 模式。

BTrace 植入过的代码,会一直在,直到应用重启为止。所以即使 Btrace 退出了,业务函数每次执行时都会多出一次 Btrace 是否 Attach 状态的判断。

为了保证程序的安全,BTrace对编写的脚本进行了一些限制,比如不允许在脚本中创建对象,不允许在脚本中抛出异常等,更详细的限制请参考 BTrace 使用限制

推荐阅读:

  1. Btrace入门到熟练小工完全指南
  2. 如何在生产环境使用Btrace进行调试
  3. BTrace使用小结
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-04-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • BTrace 是什么?
  • BTrace 能干什么?
  • BTrace 快速开始
    • btrace
      • btracec
      • BTrace 脚本
      相关产品与服务
      云服务器
      云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档