spring boot 多线程/异步执行

spring boot 多线程/异步执行

对于spring boot的多线程/异步执行的介绍全网多如牛毛。对于线程池的监测寥寥无几,且“又臭又长”还搬来搬去的。耗费半天时间终于在Google找到一篇国内的文章:在spring boot应用监控线程池的状态,多亏这篇文章给我指点了迷津。
项目众多,且忘性比记性好,遂写下来为自己作为字典,也希望能帮到寻找答案的你。

多线程配置类

@EnableAsync

//配置注解
@Configuration
//多线程配置注解
@EnableAsync
public class AsyncConfiguration {
   
    @Bean("asyncTest")
    public Executor asyncTest() {
   
        //获取jvm核心数量
        int availableProcessors = Runtime.getRuntime().availableProcessors();
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        // 核心线程数:线程池创建时候初始化的线程数
        executor.setCorePoolSize(availableProcessors*2);
        // 最大线程数:线程池最大的线程数,只有在缓冲队列满了之后才会申请超过核心线程数的线程
        executor.setMaxPoolSize(availableProcessors*6);
        // 缓冲队列:用来缓冲执行任务的队列
        executor.setQueueCapacity(800);
        // 允许线程的空闲时间60秒:当超过了核心线程之外的线程在空闲时间到达之后会被销毁
        executor.setKeepAliveSeconds(30);
        // 线程池名的前缀:设置好了之后可以方便我们定位处理任务所在的线程池
        executor.setThreadNamePrefix("async-test-");
        // 缓冲队列满了之后的拒绝策略:由调用线程处理(一般是主线程)
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.DiscardPolicy());
        executor.initialize();
        return executor;
    }
}

多线程/异步方法

@Async()多线程注解,放在方法上代表这个方法是多线程/异步的;如果放在类上代表这个类都是多线程/异步的。
多线程执行的返回值是Future类型或void。Future是非序列化的,微服务架构中有可能传递失败。
spring boot推荐使用的CompletableFuture在此次工作中没有经过测试。
调用此方法方法不能与当前方法在一个类中。

class AsyncClassOne{
   
	//只有这个方法对外是多线程/异步的
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值