arthas命令watch观察方法调用(下)

arthas
是一个 Java
开源诊断神器

上期讲过了 arthas命令watch观察方法调用(上)
中官方文档和官方的Demo演示,本期讲一下 watch
命令的实践,主要内容是针对 Demo
里面用到的命令进行演示和一些想法的尝试。其中用到了部分 ognl
的语法,这方面我比较菜,只能照猫画虎,目前来说足够我用了。还有一部分监控方法性能细节的功能将会在接下来 trace
这个命令中讲解。

此方法可以非常好地观察方法的入参返回信息,很适合线上调试,对性能影响偏大,可以错开高峰期进行 debug

arthas命令watch观察方法调用(下)

  • 点击观看视频

Demo代码

package com.fun;

import com.alibaba.fastjson.JSONObject;
import com.fun.frame.SourceCode;
import com.fun.utils.RString;
import org.slf4j.Logger;

public class Fun extends SourceCode {

int count;

public static Logger logger = getLogger(Fun.class);

public static void main(String[] args) {
Fun fun = new Fun();
while (true) {
fun.test();
sleep(1000);
output(RString.getStringWithoutNum(12));
sleep(1000);
JSONObject json = getJson("242=4324", "3242432=32423", "32432=dsdfdsf");
json.put("fun", json.clone());
json.put("fun", json.clone());
json.put("fun", json.clone());
json.put("fun", json.clone());
output(json);
try {
fun.fun();
} catch (Exception e) {

}
}


}

public void test() {
count++;
}

public String fun() {
sleep(getRandomInt(100));
int randomInt = getRandomInt(2);
if (randomInt == 1) fail();
return DEFAULT_STRING;
}


}
复制代码
  • 郑重声明
    :“FunTester”首发,欢迎关注交流,禁止第三方转载。更多原创文章
    FunTester十八张原创专辑

    ,合作请联系 Fhaohaizi@163.com

热文精选

  • Linux性能监控软件netdata中文汉化

  • 图解HTTP脑图

  • JMeter如何模拟不同的网络速度

  • 手机号验证码登录性能测试

  • 删除List中null的N种方法–最后放大招

  • 写给所有人的编程思维

  • 好书推荐《Java性能权威指南》

  • 如何成为全栈自动化工程师

  • 自动化策略六步走

  • 功能自动化测试策略

本文使用 mdnice
排版

原文 

https://juejin.im/post/5ebcd0f46fb9a043271c722b

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » arthas命令watch观察方法调用(下)

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址