异步任务
在Http协议中,基于Request<=>Response交互模型。不仅支持同步请求模式,也支持异步请求方式。而在异步任务场景中,避免客户端进入阻塞等待,请求达到并立即响应。后端一般借助线程池原理,初始化各个参数,将任务丢给线程池慢慢处理,同时响应客户端即可
Spring配置异步任务调度核心配置
/**
* ①利用@EnableAsync 注解开启异步任务支持。
* ②配置类实现AsyncConfigurer 接口并重写getAsyncExecutor 方法,并返回一个
* ThreadPoolTaskExecutor ,这样我们就获得了一个基于线程池TaskExecutor。
*/
@Configuration
@EnableAsync
public class TaskExecutorConfig implements AsyncConfigurer { // 1
@Override
public Executor getAsyncExecutor() { // 2
ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
taskExecutor.setCorePoolSize(10);
taskExecutor.setMaxPoolSize(15);
taskExecutor.setQueueCapacity(25);
taskExecutor.initialize();
return taskExecutor;
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return new SimpleAsyncUncaughtExceptionHandler();
}
}
这里线程池的执行原理不再赘述了。接下来,在我们的业务类中添加异步注解 @Async开启异步支持。这里,我们可以理解triggerData是一个十分耗时的过程
@Override
@Async
public Integer triggerData() {
List<UserCourseTmpInfo> userCourseTmpInfoList = userTmpInfoService.getUserTmp();
if (userCourseTmpInfoList == null || userCourseTmpInfoList.size() == 0) {
log.info("年报数据初始化失败,找不到相关学员数据");
return -1;
}
packageReport(userCourseTmpInfoList);
return 0;
}
并在Controller中调用异步方法
@ApiOperation(value = "初始化年报数据")
@RequestMapping(value = "/initAnnualReport", method = RequestMethod.GET)
@ResponseBody
public CommonResultDTO initAnnualReport() {
Integer i=annualReportService.triggerData();
if (i == -1) {
return CommonResultDTO.createFailureDTO("年报录入失败,请查看数据是否存在");
}
return CommonResultDTO.createSuccessDTO();
}
总结
异步任务运用场景非常常见,SpringMVC中若对某个接口要求异步响应,可以通过配置异步任务实现