在Linux服务器上使用BTrace定位调用System.gc的位置

准备BTrace

  • 下载地址:here
  • 找个目录解压

编写BTrace类

import com.sun.btrace.annotations.BTrace;
import com.sun.btrace.annotations.OnMethod;

import static com.sun.btrace.BTraceUtils.*;

@BTrace
public class TraceScript {
	@OnMethod(clazz = "java.lang.System", method = "gc")
	public static void traceExecute() {
		println("who calls System.gc:");
		jstack();
	}
}

把TraceScript 放在服务器上

 

运行待排查的程序

 

查看待排查的程序的pid

#jcmd
2231 jvm.FullGCDemo2

执行TraceScript

#cd /usr/local/tools/btrace-bin-1.3.11.3
#bin/btrace -cp ./build/ 2231 /btrace-test/TraceScript.java
who calls System.gc:
java.lang.System.gc(System.java)
jxl.read.biff.SheetImpl.clear(SheetImpl.java:687)
jxl.read.biff.WorkbookParser.close(WorkbookParser.java:518)
jvm.FullGCDemo2.main(FullGCDemo2.java:24)

上面蓝色字体所显示就是调用System.gc的位置。
总结:BTrace可以追踪知道具体方法的调用,如果不知道具体方法,可以使用谷歌提供的gperftools内存申请工具来排查。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值