Class InterfaceBasedMBeanInfoAssembler
- All Implemented Interfaces:
Aware
,BeanClassLoaderAware
,InitializingBean
,MBeanInfoAssembler
AbstractReflectiveMBeanInfoAssembler
that allows for
the management interface of a bean to be defined using arbitrary interfaces.
Any methods or properties that are defined in those interfaces are exposed
as MBean operations and attributes.
By default, this class votes on the inclusion of each operation or attribute
based on the interfaces implemented by the bean class. However, you can supply an
array of interfaces via the managedInterfaces
property that will be
used instead. If you have multiple beans and you wish each bean to use a different
set of interfaces, then you can map bean keys (that is the name used to pass the
bean to the MBeanExporter
) to a list of interface names using the
interfaceMappings
property.
If you specify values for both interfaceMappings
and
managedInterfaces
, Spring will attempt to find interfaces in the
mappings first. If no interfaces for the bean are found, it will use the
interfaces defined by managedInterfaces
.
- Since:
- 1.2
- Author:
- Rob Harrop, Juergen Hoeller
- See Also:
-
Field Summary
Fields inherited from class org.springframework.jmx.export.assembler.AbstractReflectiveMBeanInfoAssembler
ATTRIBUTE_OPERATION_VISIBILITY, FIELD_CLASS, FIELD_CURRENCY_TIME_LIMIT, FIELD_DEFAULT, FIELD_DISPLAY_NAME, FIELD_GET_METHOD, FIELD_LOG, FIELD_LOG_FILE, FIELD_METRIC_CATEGORY, FIELD_METRIC_TYPE, FIELD_PERSIST_LOCATION, FIELD_PERSIST_NAME, FIELD_PERSIST_PERIOD, FIELD_PERSIST_POLICY, FIELD_ROLE, FIELD_SET_METHOD, FIELD_UNITS, FIELD_VISIBILITY, ROLE_GETTER, ROLE_OPERATION, ROLE_SETTER
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
Invoked by the containingBeanFactory
after it has set all bean properties and satisfiedBeanFactoryAware
,ApplicationContextAware
etc.protected boolean
includeOperation
(Method method, String beanKey) Check to see if theMethod
is declared in one of the configured interfaces and that it is public.protected boolean
includeReadAttribute
(Method method, String beanKey) Check to see if theMethod
is declared in one of the configured interfaces and that it is public.protected boolean
includeWriteAttribute
(Method method, String beanKey) Check to see if theMethod
is declared in one of the configured interfaces and that it is public.void
setBeanClassLoader
(ClassLoader beanClassLoader) Callback that supplies the beanclass loader
to a bean instance.void
setInterfaceMappings
(Properties mappings) Set the mappings of bean keys to a comma-separated list of interface names.void
setManagedInterfaces
(Class<?>... managedInterfaces) Set the array of interfaces to use for creating the management info.Methods inherited from class org.springframework.jmx.export.assembler.AbstractConfigurableMBeanInfoAssembler
getNotificationInfo, setNotificationInfoMappings, setNotificationInfos
Methods inherited from class org.springframework.jmx.export.assembler.AbstractReflectiveMBeanInfoAssembler
applyCurrencyTimeLimit, applyDefaultCurrencyTimeLimit, createModelMBeanOperationInfo, getAttributeDescription, getAttributeInfo, getClassForDescriptor, getDefaultCurrencyTimeLimit, getOperationDescription, getOperationInfo, getOperationParameters, getParameterNameDiscoverer, isExposeClassDescriptor, isUseStrictCasing, populateAttributeDescriptor, populateMBeanDescriptor, populateOperationDescriptor, setDefaultCurrencyTimeLimit, setExposeClassDescriptor, setParameterNameDiscoverer, setUseStrictCasing
Methods inherited from class org.springframework.jmx.export.assembler.AbstractMBeanInfoAssembler
checkManagedBean, getClassName, getClassToExpose, getClassToExpose, getConstructorInfo, getDescription, getMBeanInfo, getTargetClass
-
Constructor Details
-
InterfaceBasedMBeanInfoAssembler
public InterfaceBasedMBeanInfoAssembler()
-
-
Method Details
-
setManagedInterfaces
Set the array of interfaces to use for creating the management info. These interfaces will be used for a bean if no entry corresponding to that bean is found in theinterfaceMappings
property.- Parameters:
managedInterfaces
- an array of classes indicating the interfaces to use. Each entry MUST be an interface.- See Also:
-
setInterfaceMappings
Set the mappings of bean keys to a comma-separated list of interface names.The property key should match the bean key and the property value should match the list of interface names. When searching for interfaces for a bean, Spring will check these mappings first.
- Parameters:
mappings
- the mappings of bean keys to interface names
-
setBeanClassLoader
Description copied from interface:BeanClassLoaderAware
Callback that supplies the beanclass loader
to a bean instance.Invoked after the population of normal bean properties but before an initialization callback such as
InitializingBean's
InitializingBean.afterPropertiesSet()
method or a custom init-method.- Specified by:
setBeanClassLoader
in interfaceBeanClassLoaderAware
- Parameters:
beanClassLoader
- the owning class loader
-
afterPropertiesSet
public void afterPropertiesSet()Description copied from interface:InitializingBean
Invoked by the containingBeanFactory
after it has set all bean properties and satisfiedBeanFactoryAware
,ApplicationContextAware
etc.This method allows the bean instance to perform validation of its overall configuration and final initialization when all bean properties have been set.
- Specified by:
afterPropertiesSet
in interfaceInitializingBean
-
includeReadAttribute
Check to see if theMethod
is declared in one of the configured interfaces and that it is public.- Specified by:
includeReadAttribute
in classAbstractReflectiveMBeanInfoAssembler
- Parameters:
method
- the accessorMethod
.beanKey
- the key associated with the MBean in thebeans
Map
.- Returns:
true
if theMethod
is declared in one of the configured interfaces, otherwisefalse
.
-
includeWriteAttribute
Check to see if theMethod
is declared in one of the configured interfaces and that it is public.- Specified by:
includeWriteAttribute
in classAbstractReflectiveMBeanInfoAssembler
- Parameters:
method
- the mutatorMethod
.beanKey
- the key associated with the MBean in thebeans
Map
.- Returns:
true
if theMethod
is declared in one of the configured interfaces, otherwisefalse
.
-
includeOperation
Check to see if theMethod
is declared in one of the configured interfaces and that it is public.- Specified by:
includeOperation
in classAbstractReflectiveMBeanInfoAssembler
- Parameters:
method
- the operationMethod
.beanKey
- the key associated with the MBean in thebeans
Map
.- Returns:
true
if theMethod
is declared in one of the configured interfaces, otherwisefalse
.
-