BTrace

71 阅读1分钟

在 Java 应用性能分析与故障诊断领域,工具生态丰富多样。从动态追踪工具如 Btrace、Arthas 的 retransform 能力,到 JDB 调试,再到 JDK 内置的 VisualVM、JFR,以及 JProfiler、MAT 等性能分析工具,还有分布式监控工具、火焰图等,它们共同助力开发者高效定位问题、优化系统性能。

BTrace的 wiki:

github.com/btraceio/bt…

例子

测试代码图片btrace程序图片启动 btrace图片也可以用 arthas 实现 将 OrderProcessor 内容改一下:图片重新编译一下,然后 arthas retransform 加载:图片

可以用 jad 反编译检查一下

再看原先的程序,打印的内容变了

图片

官网的一些例子:

· github.com/btraceio/bt…

图片

对比一下

· arthas 使用了:Instrumentation.retransformClasses(),会替换整个类,风险高

· btrace 使用了:java.lang.instrument,只是在关键函数中注入了额外信息,风险低


jdb 的一个例子

编译的时候需要加 -g

图片

使用 jdb 跟踪

图片进入之后,输入 help,会列出所有调试命令
打断点做调试图片

其他一些分析工具

分布式监控

  • Prometheus
  • Grafana
  • ELK Stack
  • Zipkin
  • Jaeger

Arthas

  • monitor、watch、trace 等很好用的工具
  • 还有 jad、dashborad、getstatic、ognl
  • profiler 记录火焰图
  • jfr,jfr 记录

JDK 内置工具

  • jstack、jinfo、jps、jmap
  • jstat、jconsole、jcmd、jhat
  • jdb
  • Mission Control

监控工具

  • visualvm
  • JFR
  • YourKit
  • JProfiler
  • Async Profiler

内存 dump分析

  • Elicpse MAT
  • NetBeans Profiler

APM 工具

  • New Relic
  • AppDynamics
  • Datadog APM

其他

  • strace
  • Perf (Linux) + async-profiler

参考

  • btrace github
  • btrace-learning
  • 通过jdb命令连接远程调试的方法
  • btrace使用入门