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 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
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.protected booleanincludeOperation(Method method, String beanKey) Check to see if theMethodis declared in one of the configured interfaces and that it is public.protected booleanincludeReadAttribute(Method method, String beanKey) Check to see if theMethodis declared in one of the configured interfaces and that it is public.protected booleanincludeWriteAttribute(Method method, String beanKey) Check to see if theMethodis declared in one of the configured interfaces and that it is public.voidsetBeanClassLoader(@Nullable ClassLoader beanClassLoader) Callback that supplies the beanclass loaderto a bean instance.voidsetInterfaceMappings(@Nullable Properties mappings) Set the mappings of bean keys to a comma-separated list of interface names.voidsetManagedInterfaces(Class<?> @Nullable ... managedInterfaces) Set the array of interfaces to use for creating the management info.Methods inherited from class AbstractConfigurableMBeanInfoAssembler
getNotificationInfo, setNotificationInfoMappings, setNotificationInfosMethods inherited from class AbstractReflectiveMBeanInfoAssembler
applyCurrencyTimeLimit, applyDefaultCurrencyTimeLimit, createModelMBeanOperationInfo, getAttributeDescription, getAttributeInfo, getClassForDescriptor, getDefaultCurrencyTimeLimit, getOperationDescription, getOperationInfo, getOperationParameters, getParameterNameDiscoverer, isExposeClassDescriptor, isUseStrictCasing, populateAttributeDescriptor, populateMBeanDescriptor, populateOperationDescriptor, setDefaultCurrencyTimeLimit, setExposeClassDescriptor, setParameterNameDiscoverer, setUseStrictCasingMethods inherited from class 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 theinterfaceMappingsproperty.- 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:BeanClassLoaderAwareCallback that supplies the beanclass loaderto a bean instance.Invoked after the population of normal bean properties but before an initialization callback such as
InitializingBean'sInitializingBean.afterPropertiesSet()method or a custom init-method.- Specified by:
setBeanClassLoaderin interfaceBeanClassLoaderAware- Parameters:
beanClassLoader- the owning class loader
-
afterPropertiesSet
public void afterPropertiesSet()Description copied from interface:InitializingBeanInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.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:
afterPropertiesSetin interfaceInitializingBean
-
includeReadAttribute
Check to see if theMethodis declared in one of the configured interfaces and that it is public.- Specified by:
includeReadAttributein classAbstractReflectiveMBeanInfoAssembler- Parameters:
method- the accessorMethod.beanKey- the key associated with the MBean in thebeansMap.- Returns:
trueif theMethodis declared in one of the configured interfaces, otherwisefalse.
-
includeWriteAttribute
Check to see if theMethodis declared in one of the configured interfaces and that it is public.- Specified by:
includeWriteAttributein classAbstractReflectiveMBeanInfoAssembler- Parameters:
method- the mutatorMethod.beanKey- the key associated with the MBean in thebeansMap.- Returns:
trueif theMethodis declared in one of the configured interfaces, otherwisefalse.
-
includeOperation
Check to see if theMethodis declared in one of the configured interfaces and that it is public.- Specified by:
includeOperationin classAbstractReflectiveMBeanInfoAssembler- Parameters:
method- the operationMethod.beanKey- the key associated with the MBean in thebeansMap.- Returns:
trueif theMethodis declared in one of the configured interfaces, otherwisefalse.
-