简单的Spring Batch示例
使用Spring Batch做為批處理框架,可以完成常規(guī)的數(shù)據(jù)量不是特別大的離線計(jì)算。
現(xiàn)在寫(xiě)一個(gè)簡(jiǎn)單的入門(mén)版示例。
這里默認(rèn)大家已經(jīng)掌握了Spring Batch的基本知識(shí),示例只是為了快速上手實(shí)踐
目標(biāo)1:程序隨機(jī)生成字符串,經(jīng)過(guò)Spring Batch后,統(tǒng)一在字符串后加入“----PROCESSED”,并輸出
目標(biāo)2:程序讀取txt文件,經(jīng)過(guò)Spring Batch后,統(tǒng)一加入如上字段,并輸出
Spring Batch的流程
讀取數(shù)據(jù)----itemReader
處理數(shù)據(jù)----itemProcess
數(shù)據(jù)寫(xiě)入----itemWrite
分析目標(biāo)可知,兩個(gè)目標(biāo)的輸入數(shù)據(jù)源不同,處理方式基本一致,數(shù)據(jù)完成后的寫(xiě)入規(guī)則一致
由此可以分段完成代碼
itemReader
目標(biāo)一
這里沒(méi)有使用Spring Batch自帶的集中reader,所以自定義了隨機(jī)生成字符串的reader
這里代碼并不完善,reader會(huì)無(wú)線循環(huán)生成隨機(jī)字符串,但不影響本次學(xué)習(xí)的目的
public class MyItemReader implements ItemReader<String> {
@Override
public String read() throws Exception, UnexpectedInputException, ParseException, NonTransientResourceException {
return RandomStringUtils.randomAlphabetic(10);
}
}
目標(biāo)二
由于是讀取文件中的內(nèi)容,所以不用自定義reader實(shí)現(xiàn),可直接使用FlatFileItemReader,在Batch的config中配置即可
@Bean
public ItemReader<String> textReader(){
FlatFileItemReader<String> reader=new FlatFileItemReader<>();
File file = new File("D:\FTP\ttest.txt");
reader.setResource(new FileSystemResource(file));
reader.setLineMapper(new LineMapper<String>() {
@Override
public String mapLine(String line, int lineNumber) throws Exception {
return line;
}
});
return reader;
}
itemProcess
這里采用同一種處理方式即可
public class MyItemProcessor implements ItemProcessor<String,String> {
@Override
public String process(String s) throws Exception {
return s+"---------PROCESSED";
}
}
itemWriter
也采用同一種即可
public class MyItemWriter implements ItemWriter<String> {
@Override
public void write(List<? extends String> items) throws Exception {
for (String item : items) {
System.out.println(item);
}
}
}
配置完成Batch Config
@Configuration
@EnableBatchProcessing
public class BatchConfiguration extends DefaultBatchConfigurer {
@Autowired
public StepBuilderFactory stepBuilderFactory;
@Autowired
public JobBuilderFactory jobBuilderFactory;
@Bean
public MyItemProcessor processor(){
return new MyItemProcessor();
}
@Bean
public ItemWriter<String> writer(){
return new MyItemWriter();
}
@Bean
public ItemReader<String> textReader(){
FlatFileItemReader<String> reader=new FlatFileItemReader<>();
File file = new File("D:\FTP\ttest.txt");
reader.setResource(new FileSystemResource(file));
reader.setLineMapper(new LineMapper<String>() {
@Override
public String mapLine(String line, int lineNumber) throws Exception {
return line;
}
});
return reader;
}
@Bean
public ItemReader<String> stringReader(){
return new MyItemReader();
}
@Override
public void setDataSource(DataSource dataSource) {
super.setDataSource(dataSource);
}
@Bean
public Step myStep(){
return stepBuilderFactory
.get("step1")
//這個(gè)chunk size是最后調(diào)用寫(xiě)入的時(shí)候,一次性寫(xiě)入多少條已處理的數(shù)據(jù)
.<String,String>chunk(10)
// .reader(textReader())
.reader(stringReader())
.processor(processor())
.writer(writer())
.build();
}
@Bean
public Job MyJob(){
return jobBuilderFactory
.get("MyJOB")
.listener(new JobExecutionListenerSupport(){
//所有處理結(jié)束后調(diào)用
@Override
public void afterJob(JobExecution jobExecution) {
if(jobExecution.getStatus() == BatchStatus.COMPLETED){
System.out.println("OK");
}
}
})
.flow(myStep())
.end()
.build();
}
}
結(jié)束
最后直接運(yùn)行spring boot程序即可
總結(jié)
以上是生活随笔為你收集整理的简单的Spring Batch示例的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 什么是轻断食(5 2轻断食一个月能瘦多少
- 下一篇: 怎么创建具有真实纹理的CG场景岩石?