之前做异步的时候通常都是用消息队列来做,今天使用spring的异步任务
首先异步任务需要定义线程池,spring异步提供了默认线程池,但是线程池通常都是自己定义,这样更能符合业务需求。
将自定义线程池注入到sprin中,并设置异步任务异常捕获处理器
package com.imooc.ecommerce.config;
import com.alibaba.fastjson.JSON;
import lombok.extern.slf4j.Slf4j;
import org.springframework.aop.interceptor.AsyncUncaughtExceptionHandler;
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.lang.reflect.Method;
import java.util.concurrent.Executor;
import java.util.concurrent.ThreadPoolExecutor;
/**
* Created By 丛梓祺 on 2021/11/9
* Write this code and change the world
* 自定义异步任务线程池 异步任务异常捕获处理器
*/
@Slf4j
@EnableAsync //开启spring 异步任务支持
@Configuration
public class AsyncPoolConfig implements AsyncConfigurer {
/**
* 将自定义线程池注入到spring容器中
*
* @return
*/
@Bean
@Override
public Executor getAsyncExecutor() {
//spring提供的自定义线程池
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(10);
executor.setMaxPoolSize(20);
executor.setQueueCapacity(20);
executor.setKeepAliveSeconds(60);
//给这个线程池里的线程起一个名字,这个很重要
executor.setThreadNamePrefix("czq-async-");
//等待所有任务结果后再关闭线程池
executor.setWaitForTasksToCompleteOnShutdown(true);
//线程池的等待时间
executor.setAwaitTerminationSecond