Class AsyncAnnotationBeanPostProcessor
- All Implemented Interfaces:
- Serializable,- AopInfrastructureBean,- Aware,- BeanClassLoaderAware,- BeanFactoryAware,- BeanPostProcessor,- InstantiationAwareBeanPostProcessor,- SmartInstantiationAwareBeanPostProcessor,- Ordered
Async annotation at class or
 method-level by adding a corresponding AsyncAnnotationAdvisor to the
 exposed proxy (either an existing AOP proxy or a newly generated proxy that
 implements all the target's interfaces).
 The TaskExecutor responsible for the asynchronous execution may
 be provided as well as the annotation type that indicates a method should be
 invoked asynchronously. If no annotation type is specified, this post-
 processor will detect both Spring's @Async annotation as well
 as the EJB 3.1 jakarta.ejb.Asynchronous annotation.
 
For methods having a void return type, any exception thrown
 during the asynchronous method invocation cannot be accessed by the
 caller. An AsyncUncaughtExceptionHandler can be specified to handle
 these cases.
 
Note: The underlying async advisor applies before existing advisors by default, in order to switch to async execution as early as possible in the invocation chain.
- Since:
- 3.0
- Author:
- Mark Fisher, Juergen Hoeller, Stephane Nicoll
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThe default name of theTaskExecutorbean to pick up: "taskExecutor".protected final LogFields inherited from class org.springframework.aop.framework.AbstractAdvisingBeanPostProcessoradvisor, beforeExistingAdvisorsFields inherited from interface org.springframework.core.OrderedHIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidconfigure(Supplier<Executor> executor, Supplier<AsyncUncaughtExceptionHandler> exceptionHandler) Configure this post-processor with the given executor and exception handler suppliers, applying the corresponding default if a supplier is not resolvable.voidsetAsyncAnnotationType(Class<? extends Annotation> asyncAnnotationType) Set the 'async' annotation type to be detected at either class or method level.voidsetBeanFactory(BeanFactory beanFactory) Callback that supplies the owning factory to a bean instance.voidsetExceptionHandler(AsyncUncaughtExceptionHandler exceptionHandler) Set theAsyncUncaughtExceptionHandlerto use to handle uncaught exceptions thrown by asynchronous method executions.voidsetExecutor(Executor executor) Set theExecutorto use when invoking methods asynchronously.Methods inherited from class org.springframework.aop.framework.autoproxy.AbstractBeanFactoryAwareAdvisingPostProcessorisEligible, prepareProxyFactoryMethods inherited from class org.springframework.aop.framework.AbstractAdvisingBeanPostProcessorcustomizeProxyFactory, determineBeanType, isEligible, postProcessAfterInitialization, setBeforeExistingAdvisorsMethods inherited from class org.springframework.aop.framework.ProxyProcessorSupportevaluateProxyInterfaces, getOrder, getProxyClassLoader, isConfigurationCallbackInterface, isInternalLanguageInterface, setBeanClassLoader, setOrder, setProxyClassLoaderMethods inherited from class org.springframework.aop.framework.ProxyConfigcopyFrom, isExposeProxy, isFrozen, isOpaque, isOptimize, isProxyTargetClass, setExposeProxy, setFrozen, setOpaque, setOptimize, setProxyTargetClass, toStringMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.beans.factory.config.BeanPostProcessorpostProcessBeforeInitializationMethods inherited from interface org.springframework.beans.factory.config.InstantiationAwareBeanPostProcessorpostProcessAfterInstantiation, postProcessBeforeInstantiation, postProcessPropertiesMethods inherited from interface org.springframework.beans.factory.config.SmartInstantiationAwareBeanPostProcessordetermineCandidateConstructors, getEarlyBeanReference, predictBeanType
- 
Field Details- 
DEFAULT_TASK_EXECUTOR_BEAN_NAMEThe default name of theTaskExecutorbean to pick up: "taskExecutor".Note that the initial lookup happens by type; this is just the fallback in case of multiple executor beans found in the context. - Since:
- 4.2
- See Also:
 
- 
logger
 
- 
- 
Constructor Details- 
AsyncAnnotationBeanPostProcessorpublic AsyncAnnotationBeanPostProcessor()
 
- 
- 
Method Details- 
configurepublic void configure(@Nullable Supplier<Executor> executor, @Nullable Supplier<AsyncUncaughtExceptionHandler> exceptionHandler) Configure this post-processor with the given executor and exception handler suppliers, applying the corresponding default if a supplier is not resolvable.- Since:
- 5.1
 
- 
setExecutorSet theExecutorto use when invoking methods asynchronously.If not specified, default executor resolution will apply: searching for a unique TaskExecutorbean in the context, or for anExecutorbean named "taskExecutor" otherwise. If neither of the two is resolvable, a local default executor will be created within the interceptor.
- 
setExceptionHandlerSet theAsyncUncaughtExceptionHandlerto use to handle uncaught exceptions thrown by asynchronous method executions.- Since:
- 4.1
 
- 
setAsyncAnnotationTypeSet the 'async' annotation type to be detected at either class or method level. By default, both theAsyncannotation and the EJB 3.1jakarta.ejb.Asynchronousannotation will be detected.This setter property exists so that developers can provide their own (non-Spring-specific) annotation type to indicate that a method (or all methods of a given class) should be invoked asynchronously. - Parameters:
- asyncAnnotationType- the desired annotation type
 
- 
setBeanFactoryDescription copied from interface:BeanFactoryAwareCallback that supplies the owning factory to a bean instance.Invoked after the population of normal bean properties but before an initialization callback such as InitializingBean.afterPropertiesSet()or a custom init-method.- Specified by:
- setBeanFactoryin interface- BeanFactoryAware
- Overrides:
- setBeanFactoryin class- AbstractBeanFactoryAwareAdvisingPostProcessor
- Parameters:
- beanFactory- owning BeanFactory (never- null). The bean can immediately call methods on the factory.
- See Also:
 
 
-