我刚开始使用Spring批处理并且遇到了这个问题。我的工作永无止境,它无限循环。以下是代码: -
@SpringBootApplication
@EnableBatchProcessing
public class Main implements CommandLineRunner{
@Autowired
private JobBuilderFactory jobBuilderFactory;
@Autowired
private StepBuilderFactory stepBuilderFactory;
@Autowired
private JobLauncher jobLauncher;
public static void main(String[] args) {
SpringApplication.run(Main.class, args);
}
@Override
public void run(String... args) throws Exception {
jobLauncher.run(flattenPersonJob(),new JobParameters());
System.out.println("Done");
}
@Bean
public ItemReader itemReader() {
return new PersonReader();
}
@Bean
public ItemProcessor itemProcessor() {
return new PersonProcessor();
}
@Bean
public ItemWriter itemWriter() {
return new PersonWriter();
}
@Bean
public Step flattenPersonStep() {
return stepBuilderFactory.get("flattenPersonStep").
chunk(1).
reader(itemReader()).
processor(itemProcessor()).
writer(itemWriter()).
build();
}
@Bean
public JobListener jobListener() {
return new JobListener();
}
@Bean
public Job flattenPersonJob() {
return jobBuilderFactory.get("flattenPersonJob").
incrementer(new RunIdIncrementer()).
listener(jobListener()).
flow(flattenPersonStep()).
end().
build();
}
}
这是我的读者课程
public class PersonReader implements ItemReader<List<Person>> {
@Override
public List<Person> read() throws Exception, UnexpectedInputException, ParseException, NonTransientResourceException {
System.out.println("This is the reader");
List<Person> personList = new ArrayList<>();
personList.add(new Person("","",""));
Thread.sleep(5000);
return personList;
}
}
这是我的作家班
public class PersonWriter implements ItemWriter<List<String>> {
@Override
public void write(List<? extends List<String>> items) throws Exception {
System.out.println("This is the writer");
//Thread.sleep(5000);
items.forEach(System.out::println);
}
}
这是我的处理器类
public class PersonProcessor implements ItemProcessor<List<Person>, List<String>> {
@Override
public List<String> process(List<Person> item) throws Exception {
System.out.println("This is the processor");
//Thread.sleep(5000);
return item.stream().map(n -> n.getName()).collect(Collectors.toList());
}
}
我在这里找不到任何配置? 或者我的代码有问题吗?
我已经用谷歌搜索了一段时间,但找不到任何有建设性的东西。
非常感谢任何帮助。
谢谢,
阿玛尔
答案 0 :(得分:4)
您的读者永远不会返回null。 Spring Batch中ItemReader
的合同是读取,直到读者返回null(表示输入已用尽)。因为你永远不会从你的ItemReader
返回null ...你的工作将永远阅读。