读书人

怎么通过btrace发现方法被哪位高手调用

发布时间: 2013-10-05 17:54:48 作者: rapoo

如何通过btrace发现方法被谁调用

最近线上某个应用Native OOM

?

?

?

目前查找Native OOM最好的方法就是用google perftools了,于是挂上google perftools,等待应用再次native oom,很幸运,两天后,应用就再次native oom了,于是分析crash之前那段时间谁在不断的分配堆外的内存,pprof看到的结果主要是java.util.Inflater造成的,由于之前 已经碰到过类似的case,知道如果使用了Inflater,但不显式的调用Inflater.end的话,确实会造成这个现象。
于是剩下的问题就是找出代码里什么地方调用了Inflater,这种时候btrace这个神器就可以发挥作用了,一个简单的btrace脚本:

?

import static com.sun.btrace.BTraceUtils.*;import com.sun.btrace.annotations.*; @BTrace public class Trace{   @OnMethod(      clazz="java.util.zip.Inflater",      method="/.*/"   )   public static void traceExecute(@ProbeMethodName String methodName){     println(concat("who call Inflater.",methodName));     jstack();   }}

?执行后很快就找到了代码什么地方调用了Inflater,于是加上了显式的调用Inflater.end,搞定收工。

?

?

参考:http://rdc.taobao.com/team/jm/archives/684

?

读书人网 >其他相关

热点推荐