springboot中实现异步方法
开启配置线程池
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 | package org.springblade.auth.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.annotation.EnableAsync; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import java.util.concurrent.ThreadPoolExecutor; /** * 线程池配置 */ @EnableAsync @Configuration public class ThreadPoolTaskConfig { /** * 核心线程数(默认线程数) */ private static final int CORE_POOL_SIZE = 5 ; /** * 最大线程数 */ private static final int MAX_POOL_SIZE = 10 ; /** * 允许线程空闲时间(单位:默认为秒) */ private static final int KEEP_ALIVE_TIME = 5 ; /** * 缓冲队列大小 */ private static final int QUEUE_CAPACITY = 50 ; /** * 线程池名前缀 */ private static final String THREAD_NAME_PREFIX = "Async-Service-" ; /** * bean的名称,默认为首字母小写的方法名 * 然后在用到的异步方法的地方,显式引用改线程池。 * 例如@Async("taskExecutor") */ @Bean ( "taskExecutor" ) public ThreadPoolTaskExecutor taskExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); executor.setCorePoolSize(CORE_POOL_SIZE); executor.setMaxPoolSize(MAX_POOL_SIZE); executor.setQueueCapacity(QUEUE_CAPACITY); executor.setKeepAliveSeconds(KEEP_ALIVE_TIME); executor.setThreadNamePrefix(THREAD_NAME_PREFIX); // 线程池对拒绝任务的处理策略 // CallerRunsPolicy:由调用线程(提交任务的线程)处理该任务 executor.setRejectedExecutionHandler( new ThreadPoolExecutor.CallerRunsPolicy()); // 初始化 executor.initialize(); return executor; } } |
1 2 3 4 5 6 7 8 9 | 方法上加上 @Async ( "taskExecutor" )注解,在其他业务类中调用就可以实现异步调用 @Override @Async ( "taskExecutor" ) public Boolean updateDoctorOrAssistantRedundanceInfo(BizUpdateDTO dto) { } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)