SpringBoot多线程
Posted *King*
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringBoot多线程相关的知识,希望对你有一定的参考价值。
Spring是通过任务执行器(TaskExecutor)来实现多线程和并发编程,使用ThreadPoolTaskExecutor来创建一个基于线城池的TaskExecutor。在使用线程池的大多数情况下都是异步非阻塞的。我们配置注解@EnableAsync可以开启异步任务。然后在实际执行的方法上配置注解@Async上声明是异步任务。
创建一个配置类:
首先使用@EnableAsync
来开启Springboot对于异步任务的支持
配置类实现接口AsyncConfigurator,返回一个ThreadPoolTaskExecutor线程池对象
@Configuration
@EnableAsync //开启异步
public class TaskConfig implements AsyncConfigurer {
@Override
public Executor getAsyncExecutor() {
// 设置线程数
ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
//核心线程数
taskExecutor.setCorePoolSize(25);
//最大线程数
taskExecutor.setMaxPoolSize(50);
//阻塞队列
taskExecutor.setQueueCapacity(100);
//初始化线程
taskExecutor.initialize();
return taskExecutor;
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return null;
}
}
ThredPoolTaskExcutor的处理流程
当池子大小小于corePoolSize,就新建线程,并处理请求
当池子大小等于corePoolSize,把请求放入workQueue中,池子里的空闲线程就去workQueue中取任务并处理
当workQueue放不下任务时,就新建线程入池,并处理请求,如果池子大小撑到了maximumPoolSize,就用RejectedExecutionHandler来做拒绝处理
当池子的线程数大于corePoolSize时,多余的线程会等待keepAliveTime长时间,如果无请求可处理就自行销毁
HelloController
@RestController
public class HelloController {
@Autowired
private HelloService helloService;
@RequestMapping("test001")
public Object test01() throws InterruptedException {
System.out.println("进入方法体");
for (int i = 0; i < 10; i++) {
helloService.asyncTask01(i);
}
return "OK";
}
}
HelloService
public interface HelloService {
void asyncTask01(int i) throws InterruptedException;
}
HelloServiceImpl
通过@Async
注解表明该方法是异步方法,如果注解在类上,那表明这个类里面的所有方法都是异步的。
@Service
public class HelloServiceImpl implements HelloService {
@Async //声明方法为异步方法
@Override
public void asyncTask01(int i) throws InterruptedException {
Thread.sleep(1000L);
System.out.println(i);
}
}
测试:
访问:http://localhost:8082/test001
以上是关于SpringBoot多线程的主要内容,如果未能解决你的问题,请参考以下文章