Insight spring-task:executor
来源:互联网 发布:知了软件 编辑:程序博客网 时间:2024/05/16 14:06
最近优化跑数的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;配置n-m,相当于配置core-size, max-size。
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);
- Insight spring-task:executor
- 源码-stage->task->taskSet->executor
- Storm中的worker Executor Task
- Insight task:annotation-driven 解析 | Insight 常识
- Storm中Worker, Executor, Task的概念
- Apache Storm 学习:Supervisor,Worker,Executor,Task
- strom之Worker、executor、task详解
- Storm中-Worker Executor Task的关系
- executor和task优先于线程
- 【Spark】worker、executor、stage、task、partition关系
- spring Task
- Spring Task
- spring task
- Spring-Task
- Spring-Task
- spring task
- spring task
- Spring Task
- SSO单点登录流程说明
- 上传工具类java
- navicat_premium for SQLServer 自带注册机
- Python 2/3 Input 区别
- 电路中电容和电感的作用
- Insight spring-task:executor
- C语言N进制推导
- 【BZOJ3625】【CF438E】小朋友和二叉树 NTT 生成函数 多项式开根 多项式求逆
- 系统设计和机器学习算法
- 11-EMM Procedure 1. Initial Attach Part2
- JS——交换两个变量(不使用第三个变量的情况下)
- 交互500+错误详解
- 没有存在感的阿里工程师
- Python迭代器和生成器