springBatch多线程设置

5 篇文章 0 订阅
4 篇文章 0 订阅

本文介绍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
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值