使用BTrace代理启动应用程序时发生NullPointerException

2020年3月9日 14点热度 0条评论

我正在使用BTrace 1.2,并遵循BTrace website中的用户指南。我在使用命令运行程序时使用BTrace没问题:

btrace <pid> AllMethods.class

但是当我尝试使用以下任一方式使用BTrace代理启动应用程序时:

java -javaagent:btrace-agent.jar=noServer=true,debug=true,script=AllMethods.class,scriptOutputFile=out.trace test/Test

要么

btracer AllMethods.class test/Test

我在
NullPointerException上得到
SimpleFileOutput

btrace DEBUG: debugMode is true
btrace DEBUG: unsafeMode is false
btrace DEBUG: dumpClasses is false
btrace DEBUG: stdout is false
btrace DEBUG: probe descriptor path is .
btrace DEBUG: initial script is AllMethods.class
btrace DEBUG: scriptOutputFile not specified. defaulting to AllMethods.class.btrace
btrace DEBUG: java.lang.NullPointerException
java.lang.NullPointerException
 at com.sun.btrace.agent.TraceOutputWriter$SimpleFileOutput.<init>(TraceOutputWriter.java:46)
 at com.sun.btrace.agent.TraceOutputWriter.fileWriter(TraceOutputWriter.java:185)
 at com.sun.btrace.agent.Main.loadBTraceScript(Main.java:334)
 at com.sun.btrace.agent.Main.parseArgs(Main.java:267)
 at com.sun.btrace.agent.Main.main(Main.java:117)
 at com.sun.btrace.agent.Main.premain(Main.java:101)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
 at java.lang.reflect.Method.invoke(Method.java:597)
 at sun.instrument.InstrumentationImpl.loadClassAndStartAgent(InstrumentationImpl.java:323)
 at sun.instrument.InstrumentationImpl.loadClassAndCallPremain(InstrumentationImpl.java:338)
btrace DEBUG: parsed command line arguments
btrace DEBUG: noServer is true, server not started

我配置了BTRACE_HOME路径。我错过了一个把戏吗?我也尝试使用1.1.3版,但没有运气。

请帮忙。

编辑

如果我设置
debug=false
stdout=true并摆脱
scriptOutputFile=out.trace输出到控制台工作正常。

解决方案如下:

事实证明,通往scriptOutputFile的路径必须是绝对路径,因此将scriptOutputFile=out.trace更改为scriptOutputFile=./out.trace可以解决此问题。