第一步:在springboot主类中加入线程池注解
@SpringBootApplication
@EnableSwagger2
@EnableScheduling
//开启线程池注解
@EnableAsync
public class MongodbApplication {
public static void main(String[] args) {
SpringApplication.run(MongodbApplication.class, args);
}
}
第二步:编写线程池配置类
@Configuration
public class ThreadAsyncConfig implements AsyncConfigurer {
@Bean
public Executor getAsyncExecutor() {
ThreadPoolTaskExecutor threadPool = new ThreadPoolTaskExecutor();
//设置核心线程数
threadPool.setCorePoolSize(10);
//设置最大线程数
threadPool.setMaxPoolSize(100);
//线程池所使用的缓冲队列
threadPool.setQueueCapacity(10);
//等待任务在关机时完成--表明等待所有线程执行完
threadPool.setWaitForTasksToCompleteOnShutdown(true);
// 等待时间 (默认为0,此时立即停止),并没等待xx秒后强制停止
threadPool.setAwaitTerminationSeconds(60);
// 线程名称前缀
threadPool.setThreadNamePrefix("MyAsync-");
// 初始化线程
threadPool.initialize();
return threadPool;
}
}
第三步:在需要用到多线程的业务层添加@Async注解
/**
* 保存用户
* @param user
*/
//添加异步操作调用线程池线程
@Async
public void save(UserEntity user){
System.out.println("线程名称:"+Thread.currentThread().getName());
userDao.save(user);
}
注意:在同一时间如果访问量大于最大线程数,将拒绝之后的访问,并且报 RejectedExecutionException错误。