- 開発言語 : Java 11
- Spring Boot : 2.2.0-RELEASE
- DBMS : MySQL 5.7
- プロダクション環境 : Ubuntu Server 18.04を想定
- 開発環境 : Windows 10, IntelliJ IDEA 2019.3
現在 Spring Batch でバッチジョブを実装中ですが、Spring Batchはジョブ実行時のパラメータが同じジョブが正常終了している場合、 JobInstanceAlreadyCompleteException
がスローされ再実行できない仕様です。
ジョブの構成は次のとおりとしています。
Java
1@Autowired 2private JobBuilderFactory jobBuilderFactory; 3 4@Bean 5public Job job1(JobExecutionListener listener, Step step1, Step step2) { 6 return jobBuilderFactory.get("job_name_1") 7 .listener(listener) 8 .incrementer(new RunIdIncrementer()) 9 .start(step1) 10 .next(step2) 11 .build(); 12}
追記:
また、上記Jobの一部を切り出した
Java
1@Bean 2public Job job2(JobExecutionListener listener, Step step2) { 3 return jobBuilderFactory.get("job_name_2") 4 .listener(listener) 5 .incrementer(new RunIdIncrementer()) 6 .start(step2) 7 .build(); 8}
もあり、 spring.batch.job.names
を外部から与えてそれぞれを実行し分ける仕組みがあります。
この状態でも gradle bootJar
でバッチの Jar を作成後
PowerShell
1PS > java "-Dspring.batch.job.names=job_name_1" -jar batch.jar "date=$(Get-Date -Format 'o')"
と、 Jar 実行時の引数として「実行ごとに変わる値」をあえてつけてやることで新しいジョブとして実行できるわけですが、これだと IDE の支援が期待できないため、このような「実行ごとに変わる値」を IntelliJ の Run Configuration で設定することはできるでしょうか。
開発中は H2 インメモリモード運用などを駆使した「そもそも Spring Batch が使用する BATCH_JOB_EXECUTION
ほかのメタデータテーブルを作らない」という選択もあるかと思いますが、プロダクション環境同様メタデータテーブルは既定のまま使用する方向でいきたいです。
あなたの回答
tips
プレビュー