前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >arthas命令watch观察方法调用(下)

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

作者头像
FunTester
发布2020-05-18 14:30:39
1.3K0
发布2020-05-18 14:30:39
举报
文章被收录于专栏:FunTester

arthas是一个Java开源诊断神器。

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

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

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

Demo代码

代码语言:javascript
复制
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
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-05-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FunTester 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • arthas命令watch观察方法调用(下)
  • Demo代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档