spring boot 如何使用多线程
2021-04-07 13:25
标签:标记 utils 方法调用 spring string 允许 并发 method lin Spring中实现多线程,其实非常简单,只需要在配置类中添加 有很多你可以配置的东西。默认情况下,使用 在定义了线程池之后,我们如何让异步调用的执行任务使用这个线程池中的资源来运行呢?方法非常简单,我们只需要在 注意事项 spring对@Transactional注解时也有类似问题,spring扫描时具有@Transactional注解方法的类时,是生成一个代理类,由代理类去开启关闭事务,而在同一个类中,方法调用是在类体内执行的,spring无法截获这个方法调用。 spring boot 如何使用多线程 标签:标记 utils 方法调用 spring string 允许 并发 method lin 原文地址:https://www.cnblogs.com/MisMe/p/13390092.htmlspring boot 如何使用多线程
@EnableAsync
就可以使用多线程。在希望执行的并发方法中使用@Async
就可以定义一个线程任务。通过spring给我们提供的ThreadPoolTaskExecutor
就可以使用线程池。第一步,先在Spring Boot主类中定义一个线程池,比如:
package com.jmxf.core.config;
import java.util.concurrent.Executor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
@Configuration
@EnableAsync // 启用异步任务
public class AsyncConfiguration {
// 组件计算
@Bean("zjExecutor")
public Executor asyncExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
//核心线程数5:线程池创建时候初始化的线程数
executor.setCorePoolSize(5);
//最大线程数5:线程池最大的线程数,只有在缓冲队列满了之后才会申请超过核心线程数的线程
executor.setMaxPoolSize(10);
//缓冲队列500:用来缓冲执行任务的队列
executor.setQueueCapacity(500);
//允许线程的空闲时间60秒:当超过了核心线程出之外的线程在空闲时间到达之后会被销毁
executor.setKeepAliveSeconds(60);
//线程池名的前缀:设置好了之后可以方便我们定位处理任务所在的线程池
executor.setThreadNamePrefix("DailyAsync-");
executor.initialize();
return executor;
}
}
SimpleAsyncTaskExecutor
。第二步,使用线程池
@Async
注解中指定线程池名即可,比如:package com.jmxf.service.fkqManage.zj;
import org.springframework.scheduling.annotation.Async;
@Service
public class CentreZj {
/**
* 多线程执行 zj计算推数
* @param fkqZj
* @throws Exception
*/
@Async("zjExecutor")
public CompletableFuture
executeZj方法被标记为Spring的 @Async 注解,表示它将在一个单独的线程上运行。该方法的返回类型是 CompleetableFuture 而不是 String,这是任何异步服务的要求。
异步方法和调用方法一定要写在不同的类中 ,如果写在一个类中,是没有效果的!
原因: