FAQ

不在本列表里的问题,请到issue里搜索。 https://github.com/alibaba/arthas/issues

日志文件在哪里?

日志文件路径: ~/logs/arthas/arthas.log

Arthas attach之后对原进程性能有多大的影响

https://github.com/alibaba/arthas/issues/44

target process not responding or HotSpot VM not loaded

com.sun.tools.attach.AttachNotSupportedException: Unable to open socket file: target process not responding or HotSpot VM not loaded

  1. 检查当前用户和目标java进程是否一致。如果不一致,则切换到同一用户。JVM只能attach同样用户下的java 进程。

  2. 尝试使用 jstack -l $pid,如果进程没有反应,则说明进程可能假死,无法响应JVM attach信号。所以同样基于attach机制的Arthas无法工作。尝试使用jmap heapdump后分析。

  3. 尝试按quick-start里的方式attach math-game。

  4. 更多情况参考: https://github.com/alibaba/arthas/issues/347

trace/watch等命令能否增强jdk里的类?

默认情况下会过滤掉java.开头的类,但可以通过参数开启。

options unsafe true

更多参考 options

怎么以json格式查看结果

options json-format true

更多参考 options

Arthas能否跟踪 native 函数

不能。

能不能查看内存里某个变量的值

  1. 可以使用vmtool命令。

  2. 可以用一些技巧,用tt命令拦截到对象,或者从静态函数里取到对象。

方法同名过滤

同名方法过滤可以通过匹配表达式,可以使用表达式核心变量中所有变量作为已知条件,可以通过判断参数个数params.length ==1, 参数类型params[0] instanceof java.lang.Integer、返回值类型 returnObj instanceof java.util.List 等等一种或者多种组合进行过滤。

可以使用 -v 查看观察匹配表达式的执行结果 https://github.com/alibaba/arthas/issues/1348

例子math-game