SpringBoot异步线程池手写代码

18 篇文章 2 订阅
14 篇文章 0 订阅

SpringBoot提供了异步线程池,废话不多说,直接上代码
代码如下:

/**
 * @author songwei
 * <p>
 * 异步线程池
 * </p>
 */
@Configuration
@EnableAsync
public class AsyncConfig implements AsyncConfigurer {
    protected Logger logger = LoggerFactory.getLogger(getClass());
    /**
     * <p>核心线程数</p>
     */
    @Value("&{asyncConfig.setCorePoolSize}")
    private Integer setCorePoolSize;

    /**
     * <p>最大线程数</p>
     */
    @Value("&{asyncConfig.setMaxPoolSize}")
    private Integer setMaxPoolSize;

    /**
     * <p>缓冲队列</p>
     */
    @Value("&{asyncConfig.setQueueCapacity}")
    private Integer setQueueCapacity;

    /**
     * <p>允许线程的空闲时间</p>
     */
    @Value("&{asyncConfig.setKeepAliveSeconds}")
    private Integer setKeepAliveSeconds;

    /**
     * <p>线程池名的前缀</p>
     */
    @Value("&{asyncConfig.setThreadNamePrefix}")
    private String setThreadNamePrefix;

    /**
     * <p>切记!切记!切记,这个地方是一个坑,也是个关键方法。设置线程池关闭的时候等待所有任务都完成再继续销毁其他的Bean</p>
     */
    @Value("&{asyncConfig.setWaitForTasksToCompleteOnShutdown}")
    private boolean setWaitForTasksToCompleteOnShutdown;

    /**
     * <p>设置线程池中任务的等待时间</p>
     */
    @Value("&{asyncConfig.setAwaitTerminationSeconds}")
    private Integer setAwaitTerminationSeconds;

    /**
     * @author songwei
     * <p>该方法是异步线程池,自动创建线程,设置线程数量,销毁时间等</p>
     * <p>setCorePoolSize:线程池创建时候初始化的线程数</p>
     * <p>setMaxPoolSize:线程池最大的线程数,只有在缓冲队列满了之后才会申请超过核心线程数的线程</p>
     * <p>setQueueCapacity:用来缓冲执行任务的队列</p>
     * <p>setKeepAliveSeconds:当超过了核心线程出之外的线程在空闲时间到达之后会被销毁</p>
     * <p>setThreadNamePrefix:设置好了之后可以方便我们定位处理任务所在的线程池</p>
     * <p>setWaitForTasksToCompleteOnShutdown:用来设置线程池关闭的时候等待所有任务都完成再继续销毁其他的Bean,这样这些异步任务的销毁就会先于Redis线程池的销毁。</p>
     * <p>setAwaitTerminationSeconds:该方法用来设置线程池中任务的等待时间,如果超过这个时候还没有销毁就强制销毁,以确保应用最后能够被关闭,而不是阻塞住。</p>
     * @return
     */
    @Bean("getAsyncExecutor")
    @Override
    public Executor getAsyncExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(setCorePoolSize);
        executor.setMaxPoolSize(setMaxPoolSize);
        executor.setQueueCapacity(setQueueCapacity);
        executor.setKeepAliveSeconds(setKeepAliveSeconds);
        executor.setThreadNamePrefix(setThreadNamePrefix);
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
        executor.setWaitForTasksToCompleteOnShutdown(setWaitForTasksToCompleteOnShutdown);
        executor.setAwaitTerminationSeconds(setAwaitTerminationSeconds);
        return executor;
    }

    @Override
    public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
    	//TDD
        return null;
    }
}

下面是YML文件的配置

#SEname:songwei
#Time:2020-03-23 11:01:39
#AsyncName: 异步线程池线程池
asyncConfig:
  setCorePoolSize: 10 #核心线程数&{setCorePoolSize}线程池创建时候初始化的线程数
  setMaxPoolSize: 20 #最大线程数&{setMaxPoolSize}:线程池最大的线程数,只有在缓冲队列满了之后才会申请超过核心线程数的线程
  setQueueCapacity: 200 #缓冲队列&{setQueueCapacity}:用来缓冲执行任务的队列
  setKeepAliveSeconds: 60 #允许线程的空闲时间&{setKeepAliveSeconds},单位为秒:当超过了核心线程出之外的线程在空闲时间到达之后会被销毁
  setThreadNamePrefix: taskExecutor- #线程池名的&{setThreadNamePrefix}:设置好了之后可以方便我们定位处理任务所在的线程池
  setWaitForTasksToCompleteOnShutdown: true #切记!切记!切记!这是关键方法,用来设置线程池关闭的时候等待所有任务都完成再继续销毁其他的Bean,这样这些异步任务的销毁就会先于Redis线程池的销毁。
  setAwaitTerminationSeconds: 60 #该方法用来设置线程池中任务的等待&{setAwaitTerminationSeconds},如果超过这个时候还没有销毁就强制销毁,以确保应用最后能够被关闭,而不是阻塞住。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值