springBatch多线程设置
来源:互联网 发布:电脑位数怎么看 mac 编辑:程序博客网 时间:2024/06/08 06:27
本文介绍springBatch 多线程两种配置方式:
本文原创,转载请标明出处,谢谢
1、第二种方式如下配置方式,reader、processor、writer都是多线程处理,处理线程数为10.但是今天我测试发现设置的线程数为n,通常只有n-1个线程在跑,猜测少的那个线程可能是作为备用线程或者是任务调度线程。
<batch:job id="Job"> <batch:step id="Step"> <batch:tasklet transaction-manager="transactionManager" task-executor="taskExecutor"> <batch:chunk reader="itemReader" writer="itemWriter" processor="itemProcessor" commit-interval="1" /> <batch:listeners> <batch:listener ref="customStepListener" /> <batch:listener ref="customItemReaderListener" /> <batch:listener ref="customItemWriterListener" /> </batch:listeners> </batch:tasklet> </batch:step></batch:job><bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor"> <property name="corePoolSize" value="10" /> <property name="maxPoolSize" value="30" /></bean>2、第二种方式如下:可以指定read 或者 writer processor 为多线程处理<batch:job id="Job"> <batch:step id="Step"> <batch:tasklet transaction-manager="transactionManager" > <batch:chunk reader="itemReader" writer="itemWriter" processor="itemProcessor" commit-interval="1" /> <batch:listeners> <batch:listener ref="customStepListener" /> <batch:listener ref="customItemReaderListener" /> <batch:listener ref="customItemWriterListener" /> </batch:listeners> </batch:tasklet> </batch:step></batch:job><bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor"> <property name="corePoolSize" value="10" /> <property name="maxPoolSize" value="30" /></bean>java:public class ItemProcessor implements ItemProcessor<String, String> { private TaskExecutor taskExecutor; public void setTaskExecutor(TaskExecutor taskExecutor) { this.taskExecutor = taskExecutor; } public String process(final String item) throws Exception { taskExecutor.execute(new Runnable() { public void run() { try { Thread current = Thread.currentThread(); System.out.println("@process: "+" "+current.getId()); System.out.println("@getName: "+current.getName()); System.out.println("@activeCount: "+current.activeCount()); System.out.println("@getId: "+current.getId()); System.out.println("@toString: "+current.toString()); } catch (Exception e) { System.out.println(e); } } }); return item; }}
0 0
- springBatch多线程设置
- SpringBatch配置多线程step
- SpringBatch前言
- SpringBatch简介
- SpringBatch简介
- SpringBatch基本概念
- SpringBatch JobExecution
- SpringBatch详解
- springMVC+springBatch
- SpringBatch的领域概念
- springbatch简介与helloworld
- springbatch操作CSV文件
- springbatch操作XML文件
- springbatch操作DB
- SpringBatch的领域概念
- 跑批利器--SpringBatch
- SpringBatch配置数据库
- Springbatch的原理
- 缓慢回到顶部
- 不用第三方比变量,交换2个变量的值
- 《JS高程(3)》DOM扩展-HTML5-第11章笔记(20)
- 对map的value值排序
- yii接值方式判断以及获取当前用户ip
- springBatch多线程设置
- ArcGIS Server无法访问服务案例处理
- Python IDE专用编辑器PyCharm下载及配置安装过程(Ubuntu环境)
- IDEA——开发工具快捷键
- Mac应用编程指南之三——核心应用设计
- 取出分组之后每组前10条数据 oracle
- poj1575
- JAVA 线程同步
- Java基础--流(2)