原文: https://howtodoinjava.com/spring-batch/java-config-multiple-steps/

学习使用 Java 配置创建 Spring Batch 作业(具有多个步骤)。 它使用 Spring Boot 2Spring Batch 4H2 数据库来执行批处理作业。

项目结构

在这个项目中,我们将创建一个包含两步任务的简单作业,并执行该作业以观察日志。 作业执行流程将是:

  1. 开始工作
  2. 执行任务一
  3. 执行任务二
  4. 完成工作

Spring Batch   Spring Boot Java 配置示例 - 图1

Spring Batch Java 配置示例

Maven 依赖

我们需要包括spring-boot-starter-batch依赖。 Spring Batch 依赖于持久性数据存储的作业存储库。 因此,我们也需要一个数据库。 我正在使用 H2(内存数据库),它与 Spring Batch 很好地集成在一起。

pom.xml

  1. <project xmlns="http://maven.apache.org/POM/4.0.0"
  2. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd;
  4. <modelVersion>4.0.0</modelVersion>
  5. <groupId>com.howtodoinjava</groupId>
  6. <artifactId>App</artifactId>
  7. <version>0.0.1-SNAPSHOT</version>
  8. <packaging>jar</packaging>
  9. <name>App</name>
  10. <url>http://maven.apache.org</url>
  11. <parent>
  12. <groupId>org.springframework.boot</groupId>
  13. <artifactId>spring-boot-starter-parent</artifactId>
  14. <version>2.0.3.RELEASE</version>
  15. </parent>
  16. <properties>
  17. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  18. </properties>
  19. <dependencies>
  20. <dependency>
  21. <groupId>org.springframework.boot</groupId>
  22. <artifactId>spring-boot-starter-batch</artifactId>
  23. </dependency>
  24. <dependency>
  25. <groupId>com.h2database</groupId>
  26. <artifactId>h2</artifactId>
  27. <scope>runtime</scope>
  28. </dependency>
  29. </dependencies>
  30. <build>
  31. <plugins>
  32. <plugin>
  33. <groupId>org.springframework.boot</groupId>
  34. <artifactId>spring-boot-maven-plugin</artifactId>
  35. </plugin>
  36. </plugins>
  37. </build>
  38. <repositories>
  39. <repository>
  40. <id>repository.spring.release</id>
  41. <name>Spring GA Repository</name>
  42. <url>http://repo.spring.io/release</url>
  43. </repository>
  44. </repositories>
  45. </project>

添加任务

第一步是创建一些任务,这些任务将按一定顺序运行以形成作业。 在 Spring Batch 中,它们实现为Tasklet

MyTaskOne.java

  1. import org.springframework.batch.core.StepContribution;
  2. import org.springframework.batch.core.scope.context.ChunkContext;
  3. import org.springframework.batch.core.step.tasklet.Tasklet;
  4. import org.springframework.batch.repeat.RepeatStatus;
  5. public class MyTaskOne implements Tasklet {
  6. public RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext) throws Exception
  7. {
  8. System.out.println("MyTaskOne start..");
  9. // ... your code
  10. System.out.println("MyTaskOne done..");
  11. return RepeatStatus.FINISHED;
  12. }
  13. }

MyTaskTwo.java

  1. import org.springframework.batch.core.StepContribution;
  2. import org.springframework.batch.core.scope.context.ChunkContext;
  3. import org.springframework.batch.core.step.tasklet.Tasklet;
  4. import org.springframework.batch.repeat.RepeatStatus;
  5. public class MyTaskTwo implements Tasklet {
  6. public RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext) throws Exception
  7. {
  8. System.out.println("MyTaskTwo start..");
  9. // ... your code
  10. System.out.println("MyTaskTwo done..");
  11. return RepeatStatus.FINISHED;
  12. }
  13. }

Spring Batch 配置

这是主要步骤,您可以定义所有与作业相关的配置及其执行逻辑。

BatchConfig.java

  1. package com.howtodoinjava.demo.config;
  2. import org.springframework.batch.core.Job;
  3. import org.springframework.batch.core.Step;
  4. import org.springframework.batch.core.configuration.annotation.EnableBatchProcessing;
  5. import org.springframework.batch.core.configuration.annotation.JobBuilderFactory;
  6. import org.springframework.batch.core.configuration.annotation.StepBuilderFactory;
  7. import org.springframework.batch.core.launch.support.RunIdIncrementer;
  8. import org.springframework.beans.factory.annotation.Autowired;
  9. import org.springframework.context.annotation.Bean;
  10. import org.springframework.context.annotation.Configuration;
  11. import com.howtodoinjava.demo.tasks.MyTaskOne;
  12. import com.howtodoinjava.demo.tasks.MyTaskTwo;
  13. @Configuration
  14. @EnableBatchProcessing
  15. public class BatchConfig {
  16. @Autowired
  17. private JobBuilderFactory jobs;
  18. @Autowired
  19. private StepBuilderFactory steps;
  20. @Bean
  21. public Step stepOne(){
  22. return steps.get("stepOne")
  23. .tasklet(new MyTaskOne())
  24. .build();
  25. }
  26. @Bean
  27. public Step stepTwo(){
  28. return steps.get("stepTwo")
  29. .tasklet(new MyTaskTwo())
  30. .build();
  31. }
  32. @Bean
  33. public Job demoJob(){
  34. return jobs.get("demoJob")
  35. .incrementer(new RunIdIncrementer())
  36. .start(stepOne())
  37. .next(stepTwo())
  38. .build();
  39. }
  40. }

示例

现在,我们的简单作业'demoJob'已配置并准备执行。 当应用程序完全启动时,我正在使用CommandLineRunner界面通过JobLauncher自动执行作业。

App.java

  1. package com.howtodoinjava.demo;
  2. import org.springframework.batch.core.Job;
  3. import org.springframework.batch.core.JobParameters;
  4. import org.springframework.batch.core.JobParametersBuilder;
  5. import org.springframework.batch.core.launch.JobLauncher;
  6. import org.springframework.beans.factory.annotation.Autowired;
  7. import org.springframework.boot.CommandLineRunner;
  8. import org.springframework.boot.SpringApplication;
  9. import org.springframework.boot.autoconfigure.SpringBootApplication;
  10. @SpringBootApplication
  11. public class App implements CommandLineRunner
  12. {
  13. @Autowired
  14. JobLauncher jobLauncher;
  15. @Autowired
  16. Job job;
  17. public static void main(String[] args)
  18. {
  19. SpringApplication.run(App.class, args);
  20. }
  21. @Override
  22. public void run(String... args) throws Exception
  23. {
  24. JobParameters params = new JobParametersBuilder()
  25. .addString("JobID", String.valueOf(System.currentTimeMillis()))
  26. .toJobParameters();
  27. jobLauncher.run(job, params);
  28. }
  29. }

注意控制台日志。

Console Logs

  1. o.s.b.c.l.support.SimpleJobLauncher : Job: [SimpleJob: [name=demoJob]] launched with
  2. the following parameters: [{JobID=1530697766768}]
  3. o.s.batch.core.job.SimpleStepHandler : Executing step: [stepOne]
  4. MyTaskOne start..
  5. MyTaskOne done..
  6. o.s.batch.core.job.SimpleStepHandler : Executing step: [stepTwo]
  7. MyTaskTwo start..
  8. MyTaskTwo done..
  9. o.s.b.c.l.support.SimpleJobLauncher : Job: [SimpleJob: [name=demoJob]] completed with
  10. the following parameters: [{JobID=1530697766768}] and the following status: [COMPLETED]

Spring 还自动运行配置的批处理作业。 要禁用作业的自动运行,您需要使用application.properties文件中的spring.batch.job.enabled属性。

application.properties

  1. spring.batch.job.enabled=false

将我的问题放在评论部分。

学习愉快!