Java Configuration
Spring 3 提供了使用 Java 而不是 XML 配置应用程序的功能。从 Spring Batch 2.2.0 开始,您可以使用相同的 Java 配置来配置批处理作业。基于 Java 的配置有三个组件:@EnableBatchProcessing
注释和两个生成器。
@EnableBatchProcessing
注释类似于 Spring 系列中的其他 @Enable*
注释。在此情况下,@EnableBatchProcessing
为批处理作业的构建提供了一个基本配置。在此基本配置中,除了使许多 bean 可用于自动注入外,还创建了 StepScope
和 JobScope
的实例:
-
JobRepository
:一个名为jobRepository
的 bean -
JobLauncher
:一个名为jobLauncher
的 bean -
JobRegistry
:一个名为jobRegistry
的 bean -
JobExplorer
:一个名为jobExplorer
的 bean -
JobOperator
: 名为jobOperator
的 bean
默认实现提供前面列出的 bean,并且要求将 DataSource
和 PlatformTransactionManager
提供为上下文中内的 bean。JobRepository
和 JobExplorer
实例使用数据源和事务管理器。默认情况下,将使用名为 dataSource
的数据源和名为 transactionManager
的事务管理器。您可以使用 @EnableBatchProcessing
注释的属性来自定义其中任何一个 bean。以下示例展示了如何提供自定义数据源和事务管理器:
@Configuration
@EnableBatchProcessing(dataSourceRef = "batchDataSource", transactionManagerRef = "batchTransactionManager")
public class MyJobConfiguration {
@Bean
public DataSource batchDataSource() {
return new EmbeddedDatabaseBuilder().setType(EmbeddedDatabaseType.HSQL)
.addScript("/org/springframework/batch/core/schema-hsqldb.sql")
.generateUniqueName(true).build();
}
@Bean
public JdbcTransactionManager batchTransactionManager(DataSource dataSource) {
return new JdbcTransactionManager(dataSource);
}
public Job job(JobRepository jobRepository) {
return new JobBuilder("myJob", jobRepository)
//define job flow as needed
.build();
}
}
只有一个配置类需要有 |
从 v5.0 开始,提供了通过 DefaultBatchConfiguration
类以编程方式配置基本基础设施 bean 的替代方式。此类提供了 @EnableBatchProcessing
提供的相同 bean,并且可以用作配置批处理作业的基本类。以下摘录是如何使用它的一个常见示例:
@Configuration
class MyJobConfiguration extends DefaultBatchConfiguration {
@Bean
public Job job(JobRepository jobRepository) {
return new JobBuilder("job", jobRepository)
// define job flow as needed
.build();
}
}
数据源和事务管理器将从应用程序上下文中解析,并在作业存储库和作业资源管理器上设置。您可以通过覆盖所需的设置器来自定义任何基础设施 bean 的配置。以下示例展示了如何自定义实例的字符编码:
@Configuration
class MyJobConfiguration extends DefaultBatchConfiguration {
@Bean
public Job job(JobRepository jobRepository) {
return new JobBuilder("job", jobRepository)
// define job flow as needed
.build();
}
@Override
protected Charset getCharset() {
return StandardCharsets.ISO_8859_1;
}
}
|