Spring Batch之Job的异步执行(八)

        JobLauncher支持对作业的同步、异步两种调用模式。默认情况下,JobLauncher的run操作通过同步方式调用Job,即任何调用Job的客户端需要等待Job的执行结果返回后才能结束。

        现在可以通过异步调用模式,即调用Job的客户端无需一直等待Job执行结果,可以先返回,等过段时间来查询当前作业的执行情况。

一、异步调用配置

(1).配置一个线程池

(2).为JobLauncher配置线程池

二、项目举例

1.项目架构

2.代码实现

Demo7BatchMain.java:

package com.xj.demo7;

import org.springframework.batch.core.Job;
import org.springframework.batch.core.JobExecution;
import org.springframework.batch.core.JobParameters;
import org.springframework.batch.core.launch.JobLauncher;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

/**
 * @Author : xjfu
 * @Date : 2021/11/18 8:37
 * @Description :异步JobLauncher测试
 */
public class Demo7BatchMain {

    public static void main(String[] args) {
        Demo7BatchMain batchMain = new Demo7BatchMain();

        batchMain.executeJob("demo7/job/demo7-job.xml", "jobLauncher", "demo7Job", new JobParameters());
    }
    
    public  void executeJob(String jobXmlPath, String jobLauncherId, String jobId, JobParameters jobParameters){

        //获取Job的配置文件
        ApplicationContext context = new ClassPathXmlApplicationContext(jobXmlPath);
        //获取JobLauncher
        JobLauncher jobLauncher = (JobLauncher) context.getBean(jobLauncherId);
        //获取要执行的Job
        Job job = (Job)context.getBean(jobId);

        try {
            //执行Job
            JobExecution result = jobLauncher.run(job,jobParameters);
            //输出执行结果
            System.out.println(result.toString());
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

MyTasklet.java:

package com.xj.demo7;

import org.springframework.batch.core.StepContribution;
import org.springframework.batch.core.scope.context.ChunkContext;
import org.springframework.batch.core.step.tasklet.Tasklet;
import org.springframework.batch.repeat.RepeatStatus;

/**
 * @Author : xjfu
 * @Date : 2021/11/18 8:49
 * @Description :demo7的Tasklet
 */
public class MyTasklet implements Tasklet {
    @Override
    public RepeatStatus execute(StepContribution stepContribution, ChunkContext chunkContext) throws Exception {

        System.out.println("*****demo7的MyTasklet执行啦*****");

        return RepeatStatus.FINISHED;
    }
}

demo7-job.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:batch="http://www.springframework.org/schema/batch"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/batch http://www.springframework.org/schema/batch/spring-batch.xsd">

    <import resource="classpath:demo7/job/demo7-jobContext.xml"/>

    <!--定义Job-->
    <batch:job id="demo7Job">
        <batch:step id="demo7Step">
            <batch:tasklet ref="myTasklet"/>
        </batch:step>
    </batch:job>

</beans>

demo7-jobContext.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:task="http://www.springframework.org/schema/task"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task.xsd">

    <!--定义JobRepository-->
    <bean id="jobRepository" class="org.springframework.batch.core.repository.support.MapJobRepositoryFactoryBean"/>

    <!--定义异步JobLauncher  线城池为5-->
    <task:executor id="executor" pool-size="5"/>

    <bean id="jobLauncher" class="org.springframework.batch.core.launch.support.SimpleJobLauncher">
        <property name="jobRepository" ref="jobRepository"/>
        <!--为作业调度器配置执行的线程池,作业执行期间会从线程池中选择一个线程执行Job-->
        <property name="taskExecutor" ref="executor"/>
    </bean>

    <!--定义TransactionManager-->
    <bean id="transactionManager" class="org.springframework.batch.support.transaction.ResourcelessTransactionManager"/>

    <!--定义Tasklet-->
    <bean id="myTasklet" class="com.xj.demo7.MyTasklet"/>

</beans>

3.执行结果

仔细观察控制台输出:首先是输出Job Execution的信息,然后输出具体的Job执行的具体信息。即在JobLauncher的run方法被调用后,客户单立刻返回;同时后台使用其他线程执行Job作业。 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您的Spring Batch Job在重复执行,则可能有几个原因: 1. 作业实例未正确标记为已完成 Spring Batch会在内部维护一个作业实例表,以跟踪已完成的作业。如果作业实例未正确标记为已完成,则Spring Batch会认为该作业尚未完成,从而导致重复执行。您可以在Spring Batch的元数据存储中查看作业实例表,并确保所有作业实例都已正确标记为已完成。 2. 作业配置问题 如果您的作业配置不正确,则可能导致重复执行。例如,如果您的作业配置中没有指定适当的JobParameters,则可能会导致重复执行。确保您的作业配置正确,并且您提供了正确的JobParameters。 3. 作业步骤状态问题 如果您的作业步骤状态不正确,则可能导致重复执行。例如,如果您的作业步骤在执行期间失败,但未正确标记为已失败,则可能导致Spring Batch在下一次执行时再次执行该步骤。确保您的作业步骤状态正确,并且在执行期间正确标记为已完成或已失败。 4. 定时任务问题 如果您的作业是由定时任务触发的,则可能会出现问题。例如,如果您的定时任务配置不正确,则可能会导致重复执行。确保您的定时任务配置正确,并且您已正确配置定时任务触发器。 如果您排除了以上所有问题,并且仍然看到重复执行的问题,则可能需要进一步调试。您可以使用Spring Batch的调试工具来诊断问题,并查看Spring Batch的日志以获取更多信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值