配置步骤
尽管Step,它是一个
极其复杂的类,可能包含许多协作者。
-
Java
-
XML
使用 Java 配置时,您可以使用 Spring Batch 构建器,因为 以下示例显示:
Java 配置
/**
* Note the JobRepository is typically autowired in and not needed to be explicitly
* configured
*/
@Bean
public Job sampleJob(JobRepository jobRepository, Step sampleStep) {
return new JobBuilder("sampleJob", jobRepository)
.start(sampleStep)
.build();
}
/**
* Note the TransactionManager is typically autowired in and not needed to be explicitly
* configured
*/
@Bean
public Step sampleStep(JobRepository jobRepository, (2)
PlatformTransactionManager transactionManager) { (1)
return new StepBuilder("sampleStep", jobRepository)
.<String, String>chunk(10, transactionManager) (3)
.reader(itemReader())
.writer(itemWriter())
.build();
}
| 1 | transactionManager: Spring的PlatformTransactionManager开始并提交
处理期间的事务。 |
| 2 | repository:特定于 Java 的JobRepository定期存储
这StepExecution和ExecutionContext在处理期间(就在提交之前)。 |
| 3 | chunk:依赖项的 Java 特定名称,指示这是一个
基于项目的步骤,交易前要处理的项目数为
承诺。 |
请注意,repository默认为jobRepository(通过@EnableBatchProcessing)
和transactionManager默认为transactionManager(从应用程序上下文提供)。
此外,ItemProcessor是可选的,因为 Item 可以是
直接从 reader 传递给 writer。 |
为了简化配置,您可以使用 Spring Batch XML 命名空间,因为 以下示例显示:
XML 配置
<job id="sampleJob" job-repository="jobRepository"> (2)
<step id="step1">
<tasklet transaction-manager="transactionManager"> (1)
<chunk reader="itemReader" writer="itemWriter" commit-interval="10"/> (3)
</tasklet>
</step>
</job>
| 1 | transaction-manager: Spring的PlatformTransactionManager开始并提交
处理期间的事务。 |
| 2 | job-repository:特定于 XML 的JobRepository定期存储
这StepExecution和ExecutionContext在处理期间(就在提交之前)。为
内联<step/>(在<job/>),它是<job/>元素。对于独立的<step/>,它被定义为<tasklet/>. |
| 3 | commit-interval:要处理的项目数的 XML 特定名称
在提交事务之前。 |
请注意,job-repository默认为jobRepository和transaction-manager默认为transactionManager.此外,ItemProcessor是
可选,因为该项可以直接从 Reader 传递给 Writer。 |
前面的配置包括创建面向项的 步:
-
reader:这ItemReader,它提供用于处理的项目。 -
writer:这ItemWriter处理ItemReader.