实现 Spring Batch 进度条 - 获取作业执行的总行数

clD*_*clD 5 java spring batch-processing spring-batch progress-bar

我有一个批处理作业,它使用从数据库读取HibernateCursorItemReader,使用自定义处理器处理结果,然后提交到另一个数据库。

我想显示的是相对于要处理的总项目数已处理了多少项目。

我尝试实现一个自定义JobExecutionListener,以@beforeJob从第一个表中获取行计数,然后可以Job Execution定期将其与提交进行比较。

有没有比使用监听器更好的方法Job Execution。是否可以在第一次读取时获取表的总行数,在HibernateCursorItemReader初始化期间设置一个值或类似的值?

工作

<batch:job id="SomeLongJob" job-repository="jobRepository" restartable="true">      
    <batch:listeners>
        <batch:listener ref="batchJobExecutionListener" />
    </batch:listeners>  
    <batch:step id="first1">
        <tasklet transaction-manager="hibernateTransactionManager">
            <chunk reader="hibernateItemReader"
                   processor="batchCustomProcessor"
                   writer="hibernateItemWriter"
                   skip-limit="0"
                   commit-interval="10">
            </chunk>
        </tasklet>
    </batch:step>
</batch:job>
Run Code Online (Sandbox Code Playgroud)

读者

<bean id="hibernateItemReader"
    class="org.springframework.batch.item.database.HibernateCursorItemReader">
    <property name="queryString" value="from MyTable" />
    <property name="sessionFactory" ref="sessionFactory" />
</bean>
Run Code Online (Sandbox Code Playgroud)

clD*_*clD 3

在作业开始之前获取要处理的总项目,即行

BatchJobExecutionListener.class

public void beforeJob(JobExecution jobExecution) {      
    
    int total = yourDao.getTotalRows();
    jobExecution.getExecutionContext().put("jobComplete", total);
    
}
Run Code Online (Sandbox Code Playgroud)

在作业执行期间检索总项目并与读取计数进行比较

JobWrapper.类

...
private JobExecution jobE;
...

public Long getProgress() {

    double jobComplete = (Double) jobE.getExecutionContext()
                            .get("jobComplete");
    double reads = 0;       
    for (StepExecution step : jobE.getStepExecutions()) {
        reads = reads + step.getReadCount();
    }
    return Math.round(reads / jobComplete * 100);
}
Run Code Online (Sandbox Code Playgroud)