當前位置: 首頁>>代碼示例>>Java>>正文


Java MBeanServerConnection.queryNames方法代碼示例

本文整理匯總了Java中javax.management.MBeanServerConnection.queryNames方法的典型用法代碼示例。如果您正苦於以下問題:Java MBeanServerConnection.queryNames方法的具體用法?Java MBeanServerConnection.queryNames怎麽用?Java MBeanServerConnection.queryNames使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在javax.management.MBeanServerConnection的用法示例。


在下文中一共展示了MBeanServerConnection.queryNames方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: printMBeans

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * Prints all MBeans of domain java.lang.
 * They are MBeans related to the JSR 174 that defines
 * package java.lang.management.
 */
private static void printMBeans(MBeanServerConnection mbsc) throws Exception {
    ObjectName filterName = new ObjectName("java.lang:*");
    Set<ObjectName> set = mbsc.queryNames(filterName, null);

    if ( set.size() == 0 ) {
        throw new RuntimeException("(ERROR) No MBean found with filter "
                + filterName);
    }

    System.out.println("---- MBeans found in domain java.lang :");

    for (Iterator<ObjectName> iter = set.iterator(); iter.hasNext(); ) {
        System.out.println(iter.next().toString());
    }

    System.out.println("\n") ;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:23,代碼來源:MXBeanInteropTest1.java

示例2: findObjectName

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * Find the first MBean with given canonical name and type.
 * @param mbs MBeanServerConnection to corresponding server
 * @param canonicalNamePart canonical name you are looking for
 * @param type given type for the object
 * @return ObjectName or null (default)
 */
public static ObjectName findObjectName(final MBeanServerConnection mbs, final String canonicalNamePart, final String type){
    try{
        for(final ObjectName on: mbs.queryNames(null,null)){
            final String fullObjectName = on.getCanonicalName();
            if(fullObjectName.contains(canonicalNamePart)){ //check if the canonicalNamePart is ok
                if(fullObjectName.contains(":type")){//make sure its a "valid" objectname
                    if(fullObjectName.split(":type")[1].contains(type)){//found your type
                        return on;
                    }
                }
            }
        }
    } catch (final IOException e) {
        log.log(Level.WARNING, "IO Exception during browse for ObjectNames with canonicalNamePart and given type. \n"
                + "See Stacktrace for more Information",e);
    }
    return null;
}
 
開發者ID:deB4SH,項目名稱:Byter,代碼行數:26,代碼來源:JmxHelper.java

示例3: testDataNode

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * test JMX connection to DataNode..
 * @throws Exception 
 */
@Test
public void testDataNode() throws Exception {
  int numDatanodes = 2;
  cluster = new MiniDFSCluster.Builder(config).numDataNodes(numDatanodes).build();
  cluster.waitActive();

  writeFile(cluster.getFileSystem(), new Path("/test"), 2);

  JMXGet jmx = new JMXGet();
  String serviceName = "DataNode";
  jmx.setService(serviceName);
  jmx.init();
  assertEquals(fileSize, Integer.parseInt(jmx.getValue("BytesWritten")));

  cluster.shutdown();
  MBeanServerConnection mbsc = ManagementFactory.getPlatformMBeanServer();
  ObjectName query = new ObjectName("Hadoop:service=" + serviceName + ",*");
  Set<ObjectName> names = mbsc.queryNames(query, null);
  assertTrue("No beans should be registered for " + serviceName, names.isEmpty());
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:25,代碼來源:TestJMXGet.java

示例4: printAttrs

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
private static void printAttrs(
        MBeanServerConnection mbsc1, Class<? extends Exception> expectX)
throws Exception {
    Set<ObjectName> names = mbsc1.queryNames(null, null);
    for (ObjectName name : names) {
        System.out.println(name + ":");
        MBeanInfo mbi = mbsc1.getMBeanInfo(name);
        MBeanAttributeInfo[] mbais = mbi.getAttributes();
        for (MBeanAttributeInfo mbai : mbais) {
            String attr = mbai.getName();
            Object value;
            try {
                value = mbsc1.getAttribute(name, attr);
            } catch (Exception e) {
                if (expectX != null && expectX.isInstance(e))
                    value = "<" + e + ">";
                else
                    throw e;
            }
            String s = "  " + attr + " = " + value;
            if (s.length() > 80)
                s = s.substring(0, 77) + "...";
            System.out.println(s);
        }
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:27,代碼來源:OldMBeanServerTest.java

示例5: dumpConnection

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * Dumps a local or remote MBeanServer's entire object tree for support purposes. Nested arrays and CompositeData
 * objects in MBean attribute values are handled.
 * 
 * @param connection
 *            the server connection (or server itself)
 * @param out
 *            PrintWriter to write the output to
 * @throws IOException
 *             Signals that an I/O exception has occurred.
 */
public static void dumpConnection(MBeanServerConnection connection, PrintWriter out) throws IOException
{
    JmxDumpUtil.showStartBanner(out);
    
    // Get all the object names
    Set<ObjectName> objectNames = connection.queryNames(null, null);

    // Sort the names (don't assume ObjectName implements Comparable in JDK 1.5)
    Set<ObjectName> newObjectNames = new TreeSet<ObjectName>(new Comparator<ObjectName>()
    {
        public int compare(ObjectName o1, ObjectName o2)
        {
            return o1.toString().compareTo(o2.toString());
        }
    });
    newObjectNames.addAll(objectNames);
    objectNames = newObjectNames;

    
    // Dump each MBean
    for (ObjectName objectName : objectNames)
    {
        try
        {
            printMBeanInfo(connection, objectName, out);
        }
        catch (JMException e)
        {
            // Sometimes beans can disappear while we are examining them
        }
    }
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:44,代碼來源:JmxDumpUtil.java

示例6: jmxQuery

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * Call Mbean server for some mbeans with same domain, attributes.
 *  with <em>attributebinding=true</em> you can save all attributes from all found objects
 * as your ant properties
 * @param jmxServerConnection
 * @param qry
 * @return The query result
 */
protected String jmxQuery(MBeanServerConnection jmxServerConnection,
        String qry) {
    String isError = null;
    Set<ObjectName> names = null;
    String resultproperty = getResultproperty();
    try {
        names = jmxServerConnection.queryNames(new ObjectName(qry), null);
        if (resultproperty != null) {
            setProperty(resultproperty + ".Length",Integer.toString(names.size()));
        }
    } catch (Exception e) {
        if (isEcho())
            handleErrorOutput(e.getMessage());
        return "Can't query mbeans " + qry;
    }

    if (resultproperty != null) {
        Iterator<ObjectName> it = names.iterator();
        int oindex = 0;
        String pname = null;
        while (it.hasNext()) {
            ObjectName oname = it.next();
            pname = resultproperty + "." + Integer.toString(oindex) + ".";
            oindex++;
                setProperty(pname + "Name", oname.toString());
                if (isAttributebinding()) {
                    bindAttributes(jmxServerConnection, resultproperty, pname, oname);
            
                }
            }
    }
    return isError;
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:42,代碼來源:JMXAccessorQueryTask.java

示例7: getMemberId

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
protected static String getMemberId(final String jmxManagerHost, final int jmxManagerPort,
    final String memberName) throws Exception {
  JMXConnector connector = null;

  try {
    connector = JMXConnectorFactory.connect(new JMXServiceURL(String.format(
        "service:jmx:rmi://%1$s/jndi/rmi://%1$s:%2$d/jmxrmi", jmxManagerHost, jmxManagerPort)));

    MBeanServerConnection connection = connector.getMBeanServerConnection();

    ObjectName objectNamePattern = ObjectName.getInstance("GemFire:type=Member,*");

    QueryExp query = Query.eq(Query.attr("Name"), Query.value(memberName));

    Set<ObjectName> objectNames = connection.queryNames(objectNamePattern, query);

    assertNotNull(objectNames);
    assertFalse(objectNames.isEmpty());
    assertEquals(1, objectNames.size());

    // final ObjectName objectName = ObjectName.getInstance("GemFire:type=Member,Name=" +
    // memberName);
    ObjectName objectName = objectNames.iterator().next();

    // System.err.printf("ObjectName for Member with Name (%1$s) is %2$s%n", memberName,
    // objectName);

    return ObjectUtils.toString(connection.getAttribute(objectName, "Id"));
  } finally {
    IOUtils.close(connector);
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:33,代碼來源:LauncherLifecycleCommandsDUnitTest.java

示例8: testNameNode

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * test JMX connection to NameNode..
 * @throws Exception 
 */
@Test
public void testNameNode() throws Exception {
  int numDatanodes = 2;
  cluster = new MiniDFSCluster.Builder(config).numDataNodes(numDatanodes).build();
  cluster.waitActive();

  writeFile(cluster.getFileSystem(), new Path("/test1"), 2);

  JMXGet jmx = new JMXGet();
  String serviceName = "NameNode";
  jmx.setService(serviceName);
  jmx.init(); // default lists namenode mbeans only
  assertTrue("error printAllValues", checkPrintAllValues(jmx));

  //get some data from different source
  assertEquals(numDatanodes, Integer.parseInt(
      jmx.getValue("NumLiveDataNodes")));
  assertGauge("CorruptBlocks", Long.parseLong(jmx.getValue("CorruptBlocks")),
              getMetrics("FSNamesystem"));
  assertEquals(numDatanodes, Integer.parseInt(
      jmx.getValue("NumOpenConnections")));

  cluster.shutdown();
  MBeanServerConnection mbsc = ManagementFactory.getPlatformMBeanServer();
  ObjectName query = new ObjectName("Hadoop:service=" + serviceName + ",*");
  Set<ObjectName> names = mbsc.queryNames(query, null);
  assertTrue("No beans should be registered for " + serviceName, names.isEmpty());
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:33,代碼來源:TestJMXGet.java

示例9: getMetricObjectNames

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
private Set<ObjectName> getMetricObjectNames(MBeanServerConnection mbs) {
  Set<ObjectName> objectNames = null;
  try {
    objectNames = mbs.queryNames(null, null);
  } catch (IOException e) {
    LOG.error("Failed to get object names", e);
  }
  return objectNames;
}
 
開發者ID:pinterest,項目名稱:doctorkafka,代碼行數:10,代碼來源:BrokerStatsRetriever.java

示例10: doGarbageCollectorMXBeanTest

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
private final int doGarbageCollectorMXBeanTest(MBeanServerConnection mbsc) {
    int errorCount = 0 ;
    System.out.println("---- GarbageCollectorMXBean") ;

    try {
        ObjectName filterName =
                new ObjectName(ManagementFactory.GARBAGE_COLLECTOR_MXBEAN_DOMAIN_TYPE
                + ",*");
        Set<ObjectName> onSet = mbsc.queryNames(filterName, null);

        for (Iterator<ObjectName> iter = onSet.iterator(); iter.hasNext(); ) {
            ObjectName garbageName = iter.next() ;
            System.out.println("-------- " + garbageName) ;
            MBeanInfo mbInfo = mbsc.getMBeanInfo(garbageName);
            errorCount += checkNonEmpty(mbInfo);
            System.out.println("getMBeanInfo\t\t" + mbInfo);
            GarbageCollectorMXBean garbage = null ;

            garbage =
                    JMX.newMXBeanProxy(mbsc,
                    garbageName,
                    GarbageCollectorMXBean.class) ;
            System.out.println("getCollectionCount\t\t"
                    + garbage.getCollectionCount());
            System.out.println("getCollectionTime\t\t"
                    + garbage.getCollectionTime());
        }

        System.out.println("---- OK\n") ;
    } catch (Exception e) {
        Utils.printThrowable(e, true) ;
        errorCount++ ;
        System.out.println("---- ERROR\n") ;
    }

    return errorCount ;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:38,代碼來源:MXBeanInteropTest1.java

示例11: doMemoryManagerMXBeanTest

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
private final int doMemoryManagerMXBeanTest(MBeanServerConnection mbsc) {
    int errorCount = 0 ;
    System.out.println("---- MemoryManagerMXBean") ;

    try {
        ObjectName filterName =
                new ObjectName(ManagementFactory.MEMORY_MANAGER_MXBEAN_DOMAIN_TYPE
                + ",*");
        Set<ObjectName> onSet = mbsc.queryNames(filterName, null);

        for (Iterator<ObjectName> iter = onSet.iterator(); iter.hasNext(); ) {
            ObjectName memoryManagerName = iter.next() ;
            System.out.println("-------- " + memoryManagerName) ;
            MBeanInfo mbInfo = mbsc.getMBeanInfo(memoryManagerName);
            System.out.println("getMBeanInfo\t\t" + mbInfo);
            errorCount += checkNonEmpty(mbInfo);
            MemoryManagerMXBean memoryManager = null;

            memoryManager =
                    JMX.newMXBeanProxy(mbsc,
                    memoryManagerName,
                    MemoryManagerMXBean.class) ;
            System.out.println("getMemoryPoolNames\t\t"
                    + Arrays.deepToString(memoryManager.getMemoryPoolNames()));
            System.out.println("getName\t\t"
                    + memoryManager.getName());
            System.out.println("isValid\t\t"
                    + memoryManager.isValid());
        }

        System.out.println("---- OK\n") ;
    } catch (Exception e) {
        Utils.printThrowable(e, true) ;
        errorCount++ ;
        System.out.println("---- ERROR\n") ;
    }

    return errorCount ;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:40,代碼來源:MXBeanInteropTest1.java

示例12: printMBeans

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * Prints all MBeans whatever the domain is.
 */
private static void printMBeans(MBeanServerConnection mbsc) throws Exception {
    Set<ObjectName> set = mbsc.queryNames(null, null);
    System.out.println("---- MBeans found :");

    for (Iterator<ObjectName> iter = set.iterator(); iter.hasNext(); ) {
        System.out.println(iter.next().toString());
    }

    System.out.println("\n") ;
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:14,代碼來源:MXBeanInteropTest2.java

示例13: jmxQuery

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * Call Mbean server for some mbeans with same domain, attributes. with
 * <em>attributebinding=true</em> you can save all attributes from all found
 * objects as your ant properties
 * 
 * @param jmxServerConnection
 * @param qry
 * @return The query result
 */
protected String jmxQuery(MBeanServerConnection jmxServerConnection, String qry) {
	String isError = null;
	Set<ObjectName> names = null;
	String resultproperty = getResultproperty();
	try {
		names = jmxServerConnection.queryNames(new ObjectName(qry), null);
		if (resultproperty != null) {
			setProperty(resultproperty + ".Length", Integer.toString(names.size()));
		}
	} catch (Exception e) {
		if (isEcho())
			handleErrorOutput(e.getMessage());
		return "Can't query mbeans " + qry;
	}

	if (resultproperty != null) {
		Iterator<ObjectName> it = names.iterator();
		int oindex = 0;
		String pname = null;
		while (it.hasNext()) {
			ObjectName oname = it.next();
			pname = resultproperty + "." + Integer.toString(oindex) + ".";
			oindex++;
			setProperty(pname + "Name", oname.toString());
			if (isAttributebinding()) {
				bindAttributes(jmxServerConnection, resultproperty, pname, oname);

			}
		}
	}
	return isError;
}
 
開發者ID:how2j,項目名稱:lazycat,代碼行數:42,代碼來源:JMXAccessorQueryTask.java

示例14: findObjectNames

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * Find all MBeans with the given canonical name in it.
 * Used for looking which MBeans are registered to one namespace.
 *      eg. java.net.xyz
 * @param mbs MBeanServerConnection to corresponding server.
 * @param canonicalNamePart canonical name you are looking for.
 * @return ObjectName or Null
 */
public static List<ObjectName> findObjectNames(final MBeanServerConnection mbs, final String canonicalNamePart){
    final List<ObjectName> names = new ArrayList<ObjectName>();
    try{
        for(final ObjectName on: mbs.queryNames(null,null)){
            if(on.getCanonicalName().contains(canonicalNamePart))
                names.add(on);
        }
        return names;
    } catch (final IOException e) {
        log.log(Level.WARNING, "IO Exception during browse for ObjectNames with canonicalNamePart. \n"
                + "See Stacktrace for more Information",e);
    }
    return null;
}
 
開發者ID:deB4SH,項目名稱:Byter,代碼行數:23,代碼來源:JmxHelper.java

示例15: expandMBeanNames

import javax.management.MBeanServerConnection; //導入方法依賴的package包/類
/**
 * The Configuration may contain MBean ObjectNames that are querys that need to be expanded before we can get the attributes for them.
 * If a configName starts with the {@value #OBJECT_NAME_QUERY_PREFIX} then the rest of the string is interpreted as a query to be run.
 * @param connection
 * @param config
 * @throws MalformedObjectNameException
 * @throws IOException
 * @return
 */
private static HashMap<String, String[]> expandMBeanNames(MBeanServerConnection connection, HashMap<String, String[]> config) throws MalformedObjectNameException, IOException {

    HashMap<String, String[]> expandedConfig = new LinkedHashMap<String, String[]>(config.size());

    // Expand any Query config items at the beginning
    String[] configNames = config.keySet().toArray(new String[0]);
    for (String configName : configNames) {

        if (configName.startsWith(OBJECT_NAME_QUERY_PREFIX)) {
            Set<ObjectName> realNames = connection.queryNames(new ObjectName(configName.substring(OBJECT_NAME_QUERY_PREFIX.length())), null);
            if (realNames.size() > 0) {
                for(ObjectName realName : realNames) {
                    System.err.printf("Query Found MBean %s\n", realName.getCanonicalName());
                    expandedConfig.put(realName.getCanonicalName(), config.get(configName));
                }
            }
            else {
                System.err.printf("Query Found zero (0) MBeans : %s\n", configName);
            }
        }
        else {
            expandedConfig.put(configName, config.get(configName));
        }

    }

    return expandedConfig;

}
 
開發者ID:breakEval13,項目名稱:rocketmq-flink-plugin,代碼行數:39,代碼來源:JMXClient.java


注:本文中的javax.management.MBeanServerConnection.queryNames方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。