步骤内弹簧批量取数作业参数
我有以下Spring批处理作业配置:
@Configuration
@EnableBatchProcessing
public class JobConfig {
@Autowired
private JobBuilderFactory jobBuilderFactory;
@Autowired
private StepBuilderFactory stepBuilderFactory;
@Bean
public Job job() {
return jobBuilderFactory.get("job")
.flow(stepA()).on("FAILED").to(stepC())
.from(stepA()).on("*").to(stepB()).next(stepC())
.end().build();
}
@Bean
public Step stepA() {
return stepBuilderFactory.get("stepA").tasklet(new RandomFailTasket("stepA")).build();
}
@Bean
public Step stepB() {
return stepBuilderFactory.get("stepB").tasklet(new PrintTextTasklet("stepB")).build();
}
@Bean
public Step stepC() {
return stepBuilderFactory.get("stepC").tasklet(new PrintTextTasklet("stepC")).build();
}
}
我使用以下代码开始作业:
try {
Map<String,JobParameter> parameters = new HashMap<>();
JobParameter ccReportIdParameter = new JobParameter("03061980");
parameters.put("ccReportId", ccReportIdParameter);
jobLauncher.run(job, new JobParameters(parameters));
} catch (JobExecutionAlreadyRunningException | JobRestartException | JobInstanceAlreadyCompleteException
| JobParametersInvalidException e) {
e.printStackTrace();
}
如何从作业步骤访问ccReportId
参数?
解决方案
Tasklet.execute()
方法带参数ChunkContext
,Spring Batch注入所有元数据。因此您只需通过以下元数据结构挖洞传入作业参数:
chunkContext.getStepContext().getStepExecution()
.getJobParameters().getString("ccReportId");
或其他选项是通过以下方式访问作业参数映射:
chunkContext.getStepContext().getJobParameters().get("ccReportId");
但这会给您Object
,您需要将其转换为字符串。
相关文章