Insight spring-task:executor

最近优化跑数的job,主要思路是串行拆分为并行,执行单元重构(调用外部接口需要异步)。

首先,尝试了guava 的ListeningExecutorService,对于多线程的操作确实非常方便。但不适用于我们这个场景,并发的粒度没有那么细,相对于实时响应的系统,job 不需要这样复杂的编码。

然后,继续使用喜爱的spring @Async,编码量小,体现更多的是设计,只要合理拆分执行单元,就可以轻松达到优化的效果。


使用过程中,针对task:executor 实现记录如下:

1.  不指定executor,spring 提供默认的多线程实现SimpleAsyncTaskExecutor (为每个task 创建Thread)。

2.  如果指定executor,则根据参数最终创建ThreadPoolExecutor

3.  参数pool-size,可以为n or n-m 表达式,只配置n,相当于core-size = max-size = n;配置n-m,相当于配置core-size = n, max-size = m。

4.  参数queueCapacity,rejection-policy 相对应,默认情况是queue满, abort。

5.  参数keep-alive,具体初始化为ThreadPoolExecutor 的keepAliveTime,单位为s


实例化: new ThreadPoolExecutor(this.corePoolSize, this.maxPoolSize, this.keepAliveSeconds,TimeUnit.SECONDS, queue, threadFactory, rejectedExecutionHandler);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值