public class ModelMBeanInfoSupport extends MBeanInfoimplements 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 and operations exposed via the ModelMBeanInfo for the ModelMBean 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 and operations 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.)
The serialVersionUID of this class is -1935722590756516193L.
| Constructor and Description |
|---|
ModelMBeanInfoSupport(ModelMBeanInfo
Constructs a ModelMBeanInfoSupport which is a duplicate of the given ModelMBeanInfo.
|
ModelMBeanInfoSupport(String
Creates a ModelMBeanInfoSupport with the provided information, but the descriptor is a default.
|
ModelMBeanInfoSupport(String
Creates a ModelMBeanInfoSupport with the provided information and the descriptor given in parameter.
|
| Modifier and Type | Method and Description |
|---|---|
Object |
clone()
Returns a shallow clone of this instance.
|
ModelMBeanAttributeInfo |
getAttribute(String
Returns a ModelMBeanAttributeInfo requested by name.
|
ModelMBeanConstructorInfo |
getConstructor(String
Returns the ModelMBeanConstructorInfo requested by name.
|
Descriptor |
getDescriptor()
Get the descriptor of this MBeanInfo.
|
Descriptor |
getDescriptor(String
Returns a Descriptor requested by name.
|
Descriptor |
getDescriptor(String
Returns a Descriptor requested by name and descriptorType.
|
Descriptor |
getDescriptors(String
Returns a Descriptor array consisting of all Descriptors for the ModelMBeanInfo of type inDescriptorType.
|
Descriptor |
getMBeanDescriptor()
Returns the ModelMBean's descriptor which contains MBean wide policies.
|
ModelMBeanNotificationInfo |
getNotification(String
Returns a ModelMBeanNotificationInfo requested by name.
|
ModelMBeanOperationInfo |
getOperation(String
Returns a ModelMBeanOperationInfo requested by name.
|
void |
setDescriptor(Descriptor
Sets descriptors in the info array of type inDescriptorType for the ModelMBean.
|
void |
setDescriptors(Descriptor
Adds or replaces descriptors in the ModelMBeanInfo.
|
void |
setMBeanDescriptor(Descriptor
Sets the ModelMBean's descriptor.
|
equals, getAttributes, getClassName, getConstructors, getDescription, getNotifications, getOperations, hashCode, toStringfinalize, getClass, notify, notifyAll, wait, wait, waitgetAttributes, getClassName, getConstructors, getDescription, getNotifications, getOperationspublic ModelMBeanInfoSupport(ModelMBeanInfombi)
ModelMBeanAttributeInfo[] etc) are cloned. This method is chiefly of interest to modify the Descriptor of the returned instance via
setDescriptor without affecting the Descriptor of the original object.
mbi - the ModelMBeanInfo instance from which the ModelMBeanInfo being created is initialized.
public ModelMBeanInfoSupport(StringclassName, String description, ModelMBeanAttributeInfo [] attributes, ModelMBeanConstructorInfo [] constructors, ModelMBeanOperationInfo [] operations, ModelMBeanNotificationInfo [] notifications)
className - classname of the MBean
description - human readable description of the ModelMBean
attributes - array of ModelMBeanAttributeInfo objects which have descriptors
constructors - array of ModelMBeanConstructorInfo objects which have descriptors
operations - array of ModelMBeanOperationInfo objects which have descriptors
notifications - array of ModelMBeanNotificationInfo objects which have descriptors
public ModelMBeanInfoSupport(StringclassName, String description, ModelMBeanAttributeInfo [] attributes, ModelMBeanConstructorInfo [] constructors, ModelMBeanOperationInfo [] operations, ModelMBeanNotificationInfo [] notifications, Descriptor mbeandescriptor)
className - classname of the MBean
description - human readable description of the ModelMBean
attributes - array of ModelMBeanAttributeInfo objects which have descriptors
constructors - array of ModelMBeanConstructorInfo objects which have descriptor
operations - array of ModelMBeanOperationInfo objects which have descriptor
notifications - array of ModelMBeanNotificationInfo objects which have descriptor
mbeandescriptor - descriptor to be used as the MBeanDescriptor containing MBean wide policy. If the descriptor is null, a default descriptor will be constructed. The default descriptor is: name=className, descriptorType="mbean", displayName=className, persistPolicy="never", log="F", visibility="1". If the descriptor does not contain all of these fields, the missing ones are added with these default values.
RuntimeOperationsException - Wraps an IllegalArgumentException for invalid descriptor passed in parameter. (see
getMBeanDescriptor for the definition of a valid MBean descriptor.)
public Objectclone()
ModelMBeanAttributeInfo[] etc) are cloned. This method is chiefly of interest to modify the Descriptor of the clone via
setDescriptor without affecting the Descriptor of the original object.
clone in interface
ModelMBeanInfo
clone in class
MBeanInfo
Cloneable
public Descriptor[] getDescriptors(String inDescriptorType) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
getDescriptors in interface
ModelMBeanInfo
inDescriptorType - value of descriptorType field that must be set for the descriptor to be returned. Must be "mbean", "attribute", "operation", "constructor" or "notification". If it is null or empty then all types will be returned.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException when the descriptorType in parameter is not one of: "mbean", "attribute", "operation", "constructor", "notification", empty or null.
ModelMBeanInfo.setDescriptors(javax.management.Descriptor[])
public void setDescriptors(Descriptor[] inDescriptors) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
setDescriptors in interface
ModelMBeanInfo
inDescriptors - The descriptors to be set in the ModelMBeanInfo. Null elements of the list will be ignored. All descriptors must have name and descriptorType fields.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for a null or invalid descriptor.
ModelMBeanInfo.getDescriptors(java.lang.String)
public DescriptorgetDescriptor(String inDescriptorName) throws MBeanException , RuntimeOperationsException
inDescriptorName - The name of the descriptor.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for null name.
setDescriptor(javax.management.Descriptor, java.lang.String)
public DescriptorgetDescriptor(String inDescriptorName, String inDescriptorType) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
getDescriptor in interface
ModelMBeanInfo
inDescriptorName - The name of the descriptor.
inDescriptorType - The type of the descriptor being requested. If this is null or empty then all types are searched. Valid types are 'mbean', 'attribute', 'constructor' 'operation', and 'notification'. This value will be equal to the 'descriptorType' field in the descriptor that is returned.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for a null descriptor name or null or invalid type. The type must be "mbean","attribute", "constructor", "operation", or "notification".
ModelMBeanInfo.setDescriptor(javax.management.Descriptor, java.lang.String)
public void setDescriptor(DescriptorinDescriptor, String inDescriptorType) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
setDescriptor in interface
ModelMBeanInfo
inDescriptor - The descriptor to be set in the ModelMBean. It must NOT be null. All descriptors must have name and descriptorType fields.
inDescriptorType - The type of the descriptor being set. If this is null then the descriptorType field in the descriptor is used. If specified this value must be set in the descriptorType field in the descriptor. Must be "mbean","attribute", "constructor", "operation", or "notification".
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for illegal or null arguments or if the name field of the descriptor is not found in the corresponding MBeanAttributeInfo or MBeanConstructorInfo or MBeanNotificationInfo or MBeanOperationInfo.
ModelMBeanInfo.getDescriptor(java.lang.String, java.lang.String)
public ModelMBeanAttributeInfogetAttribute(String inName) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
getAttribute in interface
ModelMBeanInfo
inName - The name of the ModelMBeanAttributeInfo to get. If no ModelMBeanAttributeInfo exists for this name null is returned.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for a null attribute name.
public ModelMBeanOperationInfogetOperation(String inName) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
getOperation in interface
ModelMBeanInfo
inName - The name of the ModelMBeanOperationInfo to get. If no ModelMBeanOperationInfo exists for this name null is returned.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for a null operation name.
public ModelMBeanConstructorInfogetConstructor(String inName) throws MBeanException , RuntimeOperationsException
inName - the name of the constructor.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for a null constructor name.
public ModelMBeanNotificationInfogetNotification(String inName) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
getNotification in interface
ModelMBeanInfo
inName - The name of the ModelMBeanNotificationInfo to get. If no ModelMBeanNotificationInfo exists for this name null is returned.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for a null notification name.
public DescriptorgetDescriptor()
MBeanInfo
getDescriptor in interface
DescriptorRead
getDescriptor in class
MBeanInfo
public DescriptorgetMBeanDescriptor() throws MBeanException
ModelMBeanInfo
Returns 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. Note that when the Type in this table is Number, a String that is the decimal representation of a Long can also be used.
| Name | Type | Meaning |
|---|---|---|
| name | String | MBean name. |
| descriptorType | String | Must be "mbean". |
| displayName | String | Name of MBean to be used in displays. |
| persistPolicy | String | One of: OnUpdate|OnTimer|NoMoreOftenThan|OnUnregister|Always|Never. See the section "MBean Descriptor Fields" in the JMX specification document. |
| persistLocation | String | The fully qualified directory name where the MBean should be persisted (if appropriate). |
| persistFile | String | File name into which the MBean should be persisted. |
| persistPeriod | Number | Frequency of persist cycle in seconds, for OnTime and NoMoreOftenThan PersistPolicy |
| currencyTimeLimit | Number | How long cached value is valid: <0 never, =0 always, >0 seconds. |
| log | String | t: log all notifications, f: log no notifications. |
| logfile | String | Fully qualified filename to log events to. |
| visibility | Number | 1-4 where 1: always visible 4: rarely visible. |
| export | String | Name to be used to export/expose this MBean so that it is findable by other JMX Agents. |
| presentationString | String | 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",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 the currencyTimeLimit field. To indicate that it is always valid, use a very large number for this field.
getMBeanDescriptor in interface
ModelMBeanInfo
MBeanException - Wraps a distributed communication Exception.
ModelMBeanInfo.setMBeanDescriptor(javax.management.Descriptor)
public void setMBeanDescriptor(DescriptorinMBeanDescriptor) throws MBeanException , RuntimeOperationsException
ModelMBeanInfo
getMBeanDescriptor method javadoc for description of valid field names.
setMBeanDescriptor in interface
ModelMBeanInfo
inMBeanDescriptor - the descriptor to set.
MBeanException - Wraps a distributed communication Exception.
RuntimeOperationsException - Wraps an IllegalArgumentException for invalid descriptor.
ModelMBeanInfo.getMBeanDescriptor()