AsyncConfig.java
package com.wilzwert.myjobs.infrastructure.configuration;
import lombok.extern.slf4j.Slf4j;
import org.springframework.aop.interceptor.AsyncUncaughtExceptionHandler;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.AsyncConfigurer;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import java.util.concurrent.Executor;
/**
*
* @author Wilhelm Zwertvaegher
* Task executor for @Async annotations
* We have to configure it to avoid beans conflicts with executor used for scheduling
*/
@Configuration
@ConditionalOnProperty(name = "application.async.enabled", havingValue = "true")
@EnableAsync
@Slf4j
public class AsyncConfig implements AsyncConfigurer {
@Override
@Bean(name = "taskExecutor")
@ConditionalOnMissingBean(name = "taskExecutor")
public Executor getAsyncExecutor() {
log.info("Creating Executor");
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(4);
executor.setMaxPoolSize(10);
executor.setQueueCapacity(100);
executor.setThreadNamePrefix("AsyncExecutor-");
executor.initialize();
return executor;
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return (throwable, method, objects) -> log.error("Exception in async method: {}", method.getName(), throwable);
}
}