SpringBoot : 异步线程池配置和使用
在spring boot中,基本上告别xml配置文件,所以本文只针对注解下的使用做介绍。
线程池
从JUC 的Java.utils.concurrent.Excutor说起,然后到TaskExecuter。其中spring对其有多个实现,其中最常用的应该是ThreadPoolTaskExecutor这里可以看一下继承关系。
异步注解@Asyns
Spring对异步支持注解
@Target({ElementType.METHOD, ElementType.TYPE})
可以作用于方法和类上。
异步调用有主要下面两个区别
- 有无参数
@Async
public void simpleTest() {
log.info(“无参,无返回”);
}
@Async
public void withParameter(String str) {
log.info(“有参,无返回。参数是={}”,str);
}
- 有无返回值,即另一种是可以返回Future
@Async
public Future asyncInvokeReturnFuture(String str) {
Future future = new AsyncResult(str);
return future;
}
线程池配置
可以新建一个Configuration类,进行线程池配置。
实现AsyncConfigurer接口对异常线程池更加细粒度的控制 。可以自定义异常处理。
/**
* 线程池配置
* @author hby
*
*/
@Configuration
@ComponentScan()//指定扫描任务执行类,默认全扫
//开始异步支持
@EnableAsync
public class AsyncConfig implements AsyncConfigurer{
private static final Logger log = LoggerFactory.getLogger(AsyncConfig.class);
@Override
public Executor getAsyncExecutor() {
//线程池
ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
taskExecutor.setCorePoolSize(5);//参数可以配到yml里面
taskExecutor.setMaxPoolSize(10);
taskExecutor.setQueueCapacity(25);
taskExecutor.initialize();
return taskExecutor;
}
// 自定义异常处理器,不做处理可以直接返回Null,使用默认处理器,将异常往抛吧
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return new MyAsycnExcupyionHandler();
}}
class MyAsyncExceptionHandler implements AsyncUncaughtExceptionHandler {
@Override
public void handleUncaughtException(Throwable throwable, Method method, Object... obj) {
log.info("Exception message - " + throwable.getMessage());
log.info("Method name - " + method.getName());
for (Object param : obj) {
log.info("Parameter value - " + param);
}
}
}
@EnableAsync开启异步调用
在springboot项目启动类上加上注解
@EnableAsync
开启异步调用。