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输入程序就可以看到输出日志:
网友评论