rthas vmtool命令主要是为了查看实例内存对象的值,比如如下代码:
public class Instance {
private static Map<String, Integer> configMap = Maps.newHashMap();
private Map<String, Integer> configMap1 = Maps.newHashMap();
public void init(){
configMap.put("AAA", 10000);
configMap.put("BBB", 20000);
configMap.put("CCC", 30000);
configMap1.put("A", 100);
configMap1.put("B", 200);
configMap1.put("C", 300);
}
}
public class Test {
private static Instance inst = new Instance();
public static void main(String[] args) throws Exception{
inst.init();
Thread.sleep(600000L);
}
}
通过vmtool命令可以查看到具体实例的值,不过该命令不能查看类变量的值,查看类变量的值需要使用到getstatic命令,比如getstatic 类名 类变量名称
此外,可以通过比如 vmtool --action getInstances --className org.example.Instance --express 'instances[0].get(4).getXX()’等调用对象的方法,支持ognl表达式,顺便提一句,arthas可以遍历某个list,然后找出里面等于某个值的对象:有时候还需要针对集合对象按某种条件进行过滤,比如想找出所有age大于5的Pojo的name,可以这样写
watch Test test “params[0].{? #this.age > 5}.{name}” -n 1