Spring Boot异步调用@Async

前往YXZ的博客了解更多

使用背景

在日常开发的项目中,当访问其他人的接口较慢或者做耗时任务时,

不想程序一直卡在耗时任务上,想程序能够并行执行,

我们可以使用多线程来并行的处理任务,也可以使用spring提供的异步处理方式@Async。

异步处理方式

调用之后,不返回任何数据。(这个文档)

调用之后,返回数据,通过Future来获取返回数据

@Async配置

@Configuration
@Async
public class AsyncTaskConfig implements AsyncConfigurer {

    // ThredPoolTaskExcutor的处理流程
    // 当池子大小小于corePoolSize,就新建线程,并处理请求
    // 当池子大小等于corePoolSize,把请求放入workQueue中,池子里的空闲线程就去workQueue中取任务并处理
    // 当workQueue放不下任务时,就新建线程入池,并处理请求,如果池子大小撑到了maximumPoolSize,就用RejectedExecutionHandler来做拒绝处理
    // 当池子的线程数大于corePoolSize时,多余的线程会等待keepAliveTime长时间,如果无请求可处理就自行销毁
    @Override
    public Executor getAsyncExecutor() {
        ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
        taskExecutor.setCorePoolSize(10);// 最小线程数
        taskExecutor.setMaxPoolSize(100);// 最大线程数
        taskExecutor.setQueueCapacity(25);// 等待队列
        taskExecutor.setKeepAliveSeconds(3000);
        taskExecutor.initialize();
        return taskExecutor;
    }

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

启用@Async配置

为了让@Async注解能够生效,还需要在Spring Boot的主程序中配置@EnableAsync

@SpringBootApplication
@EnableFeignClients//启用FeignClients
@MapperScan(basePackages = "com.iguard.scheduler.dataobject.mapper")//加载mapper
@EnableAsync//启用Async
@EnableScheduling
public class SchedulerApplication {

	public static void main(String[] args) {
		SpringApplication.run(SchedulerApplication.class, args);
	}
}

在需要异步处理的方法上添加注解@Async

@Async
    public void asyncHandleData(){
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值