码迷,mamicode.com
首页 > 其他好文 > 详细

生产环境中系统调试--BTrace

时间:2017-08-13 23:27:11      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:运行   方法   www.   lvm   tag   抛出异常   lib   jvisualvm   全局变量   

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

由于Btrace会把脚本逻辑直接侵入到运行的代码中,所以在使用上做很多限制
1、不能创建对象
2、不能使用数组
3、不能抛出或捕获异常
4、不能使用循环
5、不能使用synchronized关键字
6、属性和方法必须使用static修饰

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

Btrace可以做什么?

1、接口性能变慢,分析每个方法的耗时情况;
2、当在Map中插入大量数据,分析其扩容情况;
3、分析哪个方法调用了System.gc(),调用栈如何;
4、执行某个方法抛出异常时,分析运行时参数;

5、..........

 

BTrace已经迁移到GitHub

BTrace最新地址:https://github.com/btraceio/btrace/releases/tag/v1.3.9

相关链接:

http://www.importnew.com/23614.html

 

相关知识:

在线调试工具有哪些:

可视化的工具有:jvisualvm,jconsole(这些jvm自带的) 

控制台的工具:BTrace,greys-anatomy(第三方的,服务器调试必备)

 

原理:

java支持动态注入代码功能,这样我们可以动态的去修改已经加载的class(字节码),动态的在方法中去注入自己的监控代码。

字节码修改工具其实很多,有cglib,asm,javassist有了这些第三方的jar,你就可以动态的修改已经加载的class。

生产环境中系统调试--BTrace

标签:运行   方法   www.   lvm   tag   抛出异常   lib   jvisualvm   全局变量   

原文地址:http://www.cnblogs.com/webCrazy/p/7355148.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!