「原创声明:保留所有权利,禁止转载」
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
。
热文精选
TesterHome 为用户提供「保留所有权利,禁止转载」的选项。
除非获得原作者的单独授权,任何第三方不得转载标注了「原创声明:保留所有权利,禁止转载」的内容,否则均视为侵权。
具体请参见TesterHome 知识产权保护协议。
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
暂无回复。