Package javax.management.modelmbean

Provides the definition of the ModelMBean classes. A Model MBean is an MBean that acts as a bridge between the management interface and the underlying managed resource. Both the management interface and the managed resource are specified as Java objects. The same Model MBean implementation can be reused many times with different management interfaces and managed resources, and it can provide common functionality such as persistence and caching.

A Model MBean implements the ModelMBean interface. It is a DynamicMBean whose getMBeanInfo method returns an object implementing ModelMBeanInfo.

Every MBean has an MBeanInfo with information about the MBean itself, and its attributes, operations, constructors, and notifications. A Model MBean augments this MBeanInfo with Descriptors that encode additional information in the form of (key,value) pairs. Usually, Descriptors are instances of DescriptorSupport.

The class RequiredModelMBean provides a standard Model MBean implementation.

The following example shows a Model MBean being used to make the get method of a HashMap available for management through an MBean server. No other methods are available through the MBean server. There is nothing special about HashMap here. Public methods from any public class can be exposed for management in the same way.

import java.lang.reflect.Method;
import java.util.HashMap;
import javax.management.*;
import javax.management.modelmbean.*;

// ...

MBeanServer mbs = MBeanServerFactory.createMBeanServer();
// The MBean Server

HashMap map = new HashMap();
// The resource that will be managed

// Construct the management interface for the Model MBean
Method getMethod = HashMap.class.getMethod("get", new Class[] {Object.class});
ModelMBeanOperationInfo getInfo =
    new ModelMBeanOperationInfo("Get value for key", getMethod);
ModelMBeanInfo mmbi =
    new ModelMBeanInfoSupport(HashMap.class.getName(),
                              "Map of keys and values",
                              null,  // no attributes
                              null,  // no constructors
                              new ModelMBeanOperationInfo[] {getInfo},
                              null); // no notifications

// Make the Model MBean and link it to the resource
ModelMBean mmb = new RequiredModelMBean(mmbi);
mmb.setManagedResource(map, "ObjectReference");

// Register the Model MBean in the MBean Server
ObjectName mapName = new ObjectName(":type=Map,name=whatever");
mbs.registerMBean(mmb, mapName);

// Resource can evolve independently of the MBean
map.put("key", "value");

// Can access the "get" method through the MBean Server
mbs.invoke(mapName, "get", new Object[] {"key"}, new String[] {Object.class.getName()});
// returns "value"
Since:
1.5
Interface Description
ModelMBean

This interface must be implemented by the ModelMBeans.

ModelMBeanInfo

This interface is implemented by the ModelMBeanInfo for every ModelMBean.

ModelMBeanNotificationBroadcaster

This interface must be implemented by the ModelMBeans.

Class Description
DescriptorSupport

This class represents the metadata set for a ModelMBean element.

ModelMBeanAttributeInfo

The ModelMBeanAttributeInfo object describes an attribute of the ModelMBean.

ModelMBeanConstructorInfo

The ModelMBeanConstructorInfo object describes a constructor of the ModelMBean.

ModelMBeanInfoSupport

This class represents the meta data for ModelMBeans.

ModelMBeanNotificationInfo

The ModelMBeanNotificationInfo object describes a notification emitted by a ModelMBean.

ModelMBeanOperationInfo

The ModelMBeanOperationInfo object describes a management operation of the ModelMBean.

RequiredModelMBean

This class is the implementation of a ModelMBean.

Exception Description
InvalidTargetObjectTypeException

Exception thrown when an invalid target object type is specified.

XMLParseException

This exception is thrown when an XML formatted string is being parsed into ModelMBean objects or when XML formatted strings are being created from ModelMBean objects.

© 1993, 2020, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/11/docs/api/java.management/javax/management/modelmbean/package-summary.html