Interface: javax.management.modelmbean.ModelMBeanInfo
- public interface ModelMBeanInfo
Java resources wishing to be manageable instantiate the ModelMBean using the MBeanServer's createMBean method. The resource then sets the ModelMBeanInfo and Descriptors for the ModelMBean instance. The attributes, operations, and notifications exposed via the ModelMBeanInfo for the ModelMBean comprise the management interface and are accessible from MBeans, connectors/adaptors like other MBeans. Through the Descriptors, values and methods in the managed application can be defined and mapped to attributes and operations of the ModelMBean. This mapping can be defined during development in a file or dynamically and programmatically at runtime.
Every ModelMBean which is instantiated in the MBeanServer becomes manageable: its attributes, operations, and notifications become remotely accessible through the connectors/adaptors connected to that MBeanServer. A Java object cannot be registered in the MBeanServer unless it is a JMX compliant MBean. By instantiating a ModelMBean, resources are guaranteed that the MBean is valid. MBeanException and RuntimeOperationsException must be thrown on every public method. This allows for wrapping exceptions from distributed communications (RMI, EJB, etc.)
Methods
-
clonetop
public Object clone()Creates and returns a copy of this object. -
getAttributetop
public ModelMBeanAttributeInfo getAttribute(String inName) throws MBeanException, RuntimeOperationsExceptionReturns a ModelMBeanAttributeInfo requested by name. -
getAttributestop
public MBeanAttributeInfo[] getAttributes()Returns the list of attributes exposed for management. Each attribute is described by anMBeanAttributeInfoobject. -
getClassNametop
public String getClassName()Returns the name of the Java class of the MBean described by thisMBeanInfo. -
getConstructorstop
public MBeanConstructorInfo[] getConstructors()Returns the list of the public constructors of the MBean. Each constructor is described by anMBeanConstructorInfoobject. -
getDescriptiontop
public String getDescription()Returns a human readable description of the MBean. -
getDescriptortop
public Descriptor getDescriptor(String inDescriptorName, String inDescriptorType) throws MBeanException, RuntimeOperationsExceptionReturns a Descriptor requested by name and descriptorType. -
getDescriptorstop
public Descriptor[] getDescriptors(String inDescriptorType) throws MBeanException, RuntimeOperationsExceptionReturns a Descriptor array consisting of all Descriptors for the ModelMBeanInfo of type inDescriptorType. -
getMBeanDescriptortop
public Descriptor getMBeanDescriptor() throws MBeanException, RuntimeOperationsExceptionReturns the ModelMBean's descriptor which contains MBean wide policies. This descriptor contains metadata about the MBean and default policies for persistence and caching.The fields in the descriptor are defined, but not limited to, the following:
name : MBean name descriptorType : must be "mbean" displayName : name of attribute to be used in displays persistPolicy : OnUpdate|OnTimer|NoMoreOftenThan|OnUnregister|Always|Never persistLocation : The fully qualified directory name where the MBean should be persisted (if appropriate) persistFile : File name into which the MBean should be persisted persistPeriod : seconds - frequency of persist cycle for OnTime and NoMoreOftenThan PersistPolicy currencyTimeLimit : how long value is valid, <0 never, =0 always, >0 seconds log : where t: log all notifications f: log no notifications logfile : fully qualified filename to log events to visibility : 1-4 where 1: always visible 4: rarely visible export : name to be used to export/expose this MBean so that it is findable by other JMX Agents. presentationString : xml formatted string to allow presentation of data to be associated with the MBean.The default descriptor is: name=className,descriptorType="mbean", displayName=className, persistPolicy="never",log="F",export="F",visibility="1" If the descriptor does not contain all these fields, they will be added with these default values.
Note: because of inconsistencies in previous versions of this specification, it is recommended not to use negative or zero values for
currencyTimeLimit. To indicate that a cached value is never valid, omit thecurrencyTimeLimitfield. To indicate that it is always valid, use a very large number for this field. -
getNotificationtop
public ModelMBeanNotificationInfo getNotification(String inName) throws MBeanException, RuntimeOperationsExceptionReturns a ModelMBeanNotificationInfo requested by name. -
getNotificationstop
public MBeanNotificationInfo[] getNotifications()Returns the list of the notifications emitted by the MBean. Each notification is described by anMBeanNotificationInfoobject.In addition to any notification specified by the application, a ModelMBean may always send also two additional notifications:
- One with descriptor name "GENERIC" and displayName "jmx.modelmbean.generic"
- Second is a standard attribute change notification with descriptor name "ATTRIBUTE_CHANGE" and displayName "jmx.attribute.change"
-
getOperationtop
public ModelMBeanOperationInfo getOperation(String inName) throws MBeanException, RuntimeOperationsExceptionReturns a ModelMBeanOperationInfo requested by name. -
getOperationstop
public MBeanOperationInfo[] getOperations()Returns the list of operations of the MBean. Each operation is described by anMBeanOperationInfoobject. -
setDescriptortop
public void setDescriptor(Descriptor inDescriptor, String inDescriptorType) throws MBeanException, RuntimeOperationsExceptionSets descriptors in the info array of type inDescriptorType for the ModelMBean. The setDescriptor method of the corresponding ModelMBean*Info will be called to set the specified descriptor. -
setDescriptorstop
public void setDescriptors(Descriptor[] inDescriptors) throws MBeanException, RuntimeOperationsExceptionAdds or replaces descriptors in the ModelMBeanInfo. -
setMBeanDescriptortop
public void setMBeanDescriptor(Descriptor inDescriptor) throws MBeanException, RuntimeOperationsExceptionSets the ModelMBean's descriptor. This descriptor contains default, MBean wide metadata about the MBean and default policies for persistence and caching. This operation does a complete replacement of the descriptor, no merging is done. If the descriptor to set to is null then the default descriptor will be created. The default descriptor is: name=className,descriptorType="mbean", displayName=className, persistPolicy="never",log="F",export="F",visibility="1" If the descriptor does not contain all these fields, they will be added with these default values. See getMBeanDescriptor method javadoc for description of valid field names.
