Running a spring batch job multiple times

谁说胖子不能爱 提交于 2019-12-13 07:52:47

问题


I have created a spring batch job with spring boot using below tutorial:

https://spring.io/guides/gs/batch-processing/

The job is reading a file and writing to a database as expected.

However, now I have a use case to run this job multiple times.

I have an ArrayList of parameters.

What changes should I do to the job so that I can run the job the number of times the size of my ArrayList ?


回答1:


You can kickstart your batch job manually like this

@Component
Class Someclass{
  ...............
     @Autowired
     private JobLauncher jobLauncher;
     @Autowired
     private Job job;  

     public void someFunction(){
       jobLauncher.run(job, new JobParameters());  
   }
}

Only thing is you cannot restart a batch job if it is already completed, It throws an error saying the status is COMPLETED. For this to work you have to set allowStartIfComplete property to true. This has to be done in your batch step configuration, something like this

stepBuilderFactory.get("step1")
                .<Person, Person> chunk(10)
                .reader(reader())
                .processor(processor())
                .writer(writer())
                .allowStartIfComplete(true)
                .build();


来源:https://stackoverflow.com/questions/44326897/running-a-spring-batch-job-multiple-times

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!