On my Spring Cloud Task project I'm using Spring Batch. I want to separate the metadata (BATCH_
and TASK_
tables) from the production data, so I configure two DataSource like this:
# DataSource: Production data
prod.datasource.jdbc-url=jdbc:sqlserver://localhost;databaseName=PROD
prod.datasource.data-source-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver
prod.datasource.username=...
prod.datasource.password=...
# DataSource: Jobs and Tasks metadata
tasks.datasource.jdbc-url=jdbc:sqlserver://localhost;databaseName=TASKS
tasks.datasource.data-source-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver
tasks.datasource.username=sa
tasks.datasource.password=...
+
public class DataSourceConfig {
@Bean
@Primary
@ConfigurationProperties(prefix = "prod.datasource")
public DataSource dataSourceProd() {
return DataSourceBuilder.create().build();
}
@Bean
@ConfigurationProperties(prefix = "tasks.datasource")
public DataSource dataSourceTasks() {
return DataSourceBuilder.create().build();
}
}
+
@Configuration
@EnableTask
@EnableBatchProcessing
@Import(DataSourceConfig.class)
public class JobConfig {
@Autowired
private JobBuilderFactory jobs;
@Autowired
private StepBuilderFactory steps;
@Bean
public TaskConfigurer taskConfigurer(@Qualifier("dataSourceTasks") DataSource source) {
return new DefaultTaskConfigurer(source);
}
@Bean
public BatchConfigurer batchConfigurer(@Qualifier("dataSourceTasks") DataSource source) {
return new DefaultBatchConfigurer(source);
}
//+jobs, steps...
When I run it, I'm getting Cannot cast com.microsoft.sqlserver.jdbc.SQLServerDriver to javax.sql.DataSource
from taskConfigurer
bean. Do I miss something?
Using Spring Boot starter Batch 2.0.0.RELEASE
and Cloud starter Task 2.0.0.M3