个人视频网站注册平台,闽侯福州网站建设,wordpress 登录发布,兵团建设环保局门户网站这里写自定义目录标题 六、class和classloader6、dump7、classloader 七、monitor/watch/trace/stack等核心命令的使用1、monitor2、watch3、trace4、stack5、tt6、option7、profiler 六、class和classloader
6、dump
将已加载类的字节码文件保存到特定目录#xff1a;logs/… 这里写自定义目录标题 六、class和classloader6、dump7、classloader 七、monitor/watch/trace/stack等核心命令的使用1、monitor2、watch3、trace4、stack5、tt6、option7、profiler 六、class和classloader
6、dump
将已加载类的字节码文件保存到特定目录logs/arthas/classdump/
7、classloader
七、monitor/watch/trace/stack等核心命令的使用
1、monitor
monitor命令监控指定类中方法的执行情况 用来监视一个时间段中指定方法的执行次数成功次数失败次数耗时等这些信息
举例 过5秒监控一次类demo.MathGame中primeFactors方法 monitor -c 5 demo.MathGame primeFactors 监控的维度说明
2、watch
观察到指定方法的调用情况
作用 方法执行数据观测让你能方便的观察到指定方法的调用情况。 能观察到的范围为 返回值 、 抛出异常 、 入参 通过编写OGNL 表达式进行对应变量的查看。
参数 watch 的参数比较多主要是因为它能在 4 个不同的场景观察对象 这里重点要说明的是观察表达式观察表达式的构成主要由ognl 表达式组成所以你可以这样写 {params,returnObj} 只要是一个合法的 ognl 表达式都能被正常支持。
举例 观察demo.MathGame类中primeFactors方法出参和返回值结果属性遍历深度为2。 params表示所有参数数组(因为不确定是几个参数)returnObject表示返回值 watch demo.MathGame primeFactors “{params,returnObj}” -x 2
方法执行前进行监控 watch demo.MathGame primeFactors “{params,returnObj}” -x 2 -b
观察当前对象中的属性如果想查看方法运行前后当前对象中的属性可以使用target关键字代表当前对象 watch demo.MathGame primeFactors ‘target’ -x 2
使用target.field_name访问当前对象的某个属性 watch demo.MathGame primeFactors ‘target.illegalArgumentCount’
同时观察方法调用前和方法返回后参数里-n 2表示只执行两次。 这里输出结果中第一次输出的是方法调用前的观察表达式的结果第二次输出的是方法返回后的表达式 的结果 params表示参数target表示执行方法的对象returnObject表示返回值 watch demo.MathGame primeFactors “{params,target,returnObj}” -x 2 -b -s -n 2
条件表达式的例子输出第1参数小于的情况 watch demo.MathGame primeFactors “{params[0],target}” “params[0]0”
3、trace
对方法内部调用路径进行追踪并输出方法路径上的每个节点上耗时
trace 命令能主动搜索 class-pattern method-pattern 对应的方法调用路径渲染和统计整个调用链路上的所有性能开销和追踪调用链路 举例 trace函数指定类的指定方法 trace demo.MathGame run
如果方法调用的次数很多那么可以用-n参数指定捕捉结果的次数。比如下面的例子里捕捉到一次调用 就退出命令。 trace demo.MathGame run -n 1
默认情况下trace不会包含jdk里的函数调用如果希望trace jdk里的函数需要显式设置– skipJDKMethod false。 trace --skipJDKMethod false demo.MathGame run
据调用耗时过滤trace大于0.5ms的调用路径 trace demo.MathGame run ‘#cost .5’
4、stack
输出当前方法被调用的调用路径
很多时候我们都知道一个方法被执行但这个方法被执行的路径非常多或者你根本就不知道这个方法是从那里被执行了此时你需要的是 stack 命令。
举例 获取primeFactors的调用路径 stack demo.MathGame primeFactors
条件表达式来过滤第0个参数的值小于0-n表示获取2次 stack demo.MathGame primeFactors ‘params[0]0’ -n 2
据执行时间来过滤耗时大于0.5毫秒 stack demo.MathGame primeFactors ‘#cost0.5’
5、tt
time-tunnel 时间隧道 记录下指定方法每次调用的入参和返回信息并能对这些不同时间下调用的信息进行观测 举例 最基本的使用来说就是记录下当前方法的每次调用环境现场。 tt -t demo.MathGame primeFactors 条件表达式 不知道大家是否有在使用过程中遇到以下困惑 - Arthas 似乎很难区分出重载的方法 - 我只需要观察特定参数但是 tt 却全部都给我记录了下来 条件表达式也是用 OGNL 来编写核心的判断对象依然是 Advice 对象。除了 tt 命令之外watch 、 trace 、 stack 命令也都支持条件表达式。
解决方法重载 tt -t *Test print params.length1
通过制定参数个数的形式解决不同的方法签名如果参数个数一样你还可以这样写 tt -t *Test print ‘params[1] instanceof Integer’
解决指定参数 tt -t *Test print params[0].mobile“13989838402”
6、option
options的作用是查看或设置arthas全局环境变量
options json-format 获取option的值 options save-result true设置指定的option
7、profiler
profiler 命令支持生成应用热点的火焰图。本质上是通过不断的采样然后把收集到的采样结果生成火焰图