java – 为什么JConsole上的某些方法被禁用

前端之家收集整理的这篇文章主要介绍了java – 为什么JConsole上的某些方法被禁用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我可以看到jconsole上的一些方法被禁用了.

下面给出了com.sun.management.ThreadMXBean的屏幕截图

这些MBean方法javadocs没有指定有关可访问性部分的任何内容.

我认为这是一个安全功能,但我无法得到具体的答案.

这个问题的第二部分显而易见的是如何创建可以在jconsole上有选择地禁用的自定义MBean实现.

以下是系统配置:

JConsole version “1.7.0-b147”

Java(TM) SE Runtime Environment (build 1.7.0-b147)

Java HotSpot(TM) 64-Bit Server VM (build 21.0-b17,mixed mode)

编辑:

禁用的方法可以从独立进程中调用.

MBeanServer server = ManagementFactory.getPlatformMBeanServer();
    ObjectName name = new ObjectName("java.lang","type","Threading");
    String operationName = "getThreadAllocatedBytes";
    //1 is main thread
    Object[] params = {1};
    String[] signature = new String[]{"long"};
    Object result = server.invoke(name,operationName,params,signature);
    //Result is 682760 on my machine
    System.out.println(result);

解决方法

原因是更为温和,它们仅对采用简单类型的操作启用 – int或string.禁用的操作采用更复杂的类型,如数组(没有设施可以采用复杂的类型,没有像弹簧属性编辑器那样可以将字符串转换为复杂类型)

这是一个相关的问题:Websphere 7.X. JMX,how to enable all operations in JConsole?

更新:这是基于从OpenJDK站点http://hg.openjdk.java.net/jdk7u/jdk7u查看JConsole的源代码,根据方法签名启用或禁用操作,并将其封装在方法中 – sun.tools.jconsole.inspector.Utils.isEditable(字符串类型).允许的类型是基元,基元包装器,基元数组,

猜你在找的Java相关文章