次のSpringBatchJob構成があります。
@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
を取ります。ここで、SpringBatchはすべてのメタデータを挿入します。したがって、次のメタデータ構造を介してジョブパラメータを掘り下げる必要があります。
chunkContext.getStepContext().getStepExecution()
.getJobParameters().getString("ccReportId");
または他のオプションは、次の方法でジョブパラメータマップにアクセスすることです。
chunkContext.getStepContext().getJobParameters().get("ccReportId");
しかし、これによりObject
が得られ、文字列にキャストする必要があります。