Arthas - getstatic命令 - 监控静态字段
问题背景
想监控,这个非static类下面,的一个static变量的内容
解决方案
getstatic com.huatai.quant.service.request.ScenarioNatsRequestResponseService bookFundingCostCacheMap
当监视的static map是空的时候:
当监视的static map不是空的时候:
补充信息
可以使用getstatic方法获取到static字段的值:
getstatic com.chengjf.snippet.spring.mvc.service.impl.HelloServiceImpl HELLO_PREFIX
结果如下:
可以传入通配符获取该类的所有static字段
getstatic com.chengjf.snippet.spring.mvc.service.impl.HelloServiceImpl *
结果如下:
arthas提供了ognl这个强大的工具,也可以用来获取static字段:
ognl "@com.chengjf.snippet.spring.mvc.service.impl.HelloServiceImpl@HELLO_PREFIX"
结果如下:
但是ognl的功能远不止如此,还可以修改static字段的值:
ognl "#c=@com.chengjf.snippet.spring.mvc.service.impl.HelloServiceImpl@class,#f=#c.getDeclaredField('HELLO_PREFIX'),#f.setAccessible(true),#f.set(#c,'123')"
结果如下:
查询一下,会发现值已经被修改了:
只想上面这段命令就将HELLO_PREFIX这个static字段修改成了123。下面来看下这个命令:
- \#c=@com.chengjf.snippet.spring.mvc.service.impl.HelloServiceImpl@class,获取HelloServiceImpl这个class
- \#f=\#c.getDeclaredField('HELLO_PREFIX'),获取Field
- \#f.setAccessible(true),设置Field的修改性
- \#f.set(\#c,'123'),修改字段的值为123
参考文献
chengjf,arthas使用技巧三:静态字段大作战:https://blog.chengjf.com/t/16370/
OGNL特殊用法请参考:https://github.com/alibaba/arthas/issues/71
OGNL表达式官方指南:https://commons.apache.org/prop