@Bean("MyJob")
public Job umpInpatientCensusRptBatchJob(...) throws IOException {
return jobBuilderFactory.get( "MyJob" )
.incrementer( new RunIdIncrementer() )
.start( Step0 ).on( COMPLETE ).end()
.from( Step0 ).on( CONTINUE )
.to( Step1 )
.next( Step2 )
.next( Step3 )
.end()
.build();
}
一个明显的问题是第一个on()中的单词“complete”。方法on(String pattern)被指定为“Complete”作为参数,而不是例如“Completed”,如果没有创建适当的自定义退出状态,则作业以失败状态完成。然而,我不知道为什么它挂了,并不只是失败在你的情况下。只要所有tasklet返回一个完成的repeatstatus,以下版本的作业配置似乎可以正常运行:
@Bean("MyJob")
public Job umpInpatientCensusRptBatchJob(...) throws IOException {
return jobBuilderFactory.get( "MyJob" )
.incrementer( new RunIdIncrementer() )
.start( Step0 ).on( "COMPLETED" ).end()
.from( Step0 ).on( "CONTINUE" )
.to( Step1 )
.next( Step2 )
.next( Step3 )
.end()
.build();
}
如果Step0的tasklet返回repeatstatus.continuable,那么Step0将永远重复,因为这是repeatstatus的目的。所以,用这种配置是不可能达到Step1的。为了决定是否应该运行下一个步骤,而不是使用tasklet repeat状态(我不知道是否可能),您可以在Step0上使用StepExecuthtml" target="_blank">ionListener,或者在Step0之后向流添加一个决定符:
Spring-batch:如何从StepListener返回自定义作业退出状态以决定下一步
我有一个Spring批处理tasklet,我不知道如何从中失败。我想检查某些参数,如果它们不存在,则在该步骤中使作业失败。 注释掉的行是我试图让工作退出的行。有人有过这样的经历吗?
我最近开始使用java配置方式编写spring批处理程序,并使用spring批处理和starter包。我使用了分区的步骤和任务执行器来完成我的工作,我面临的问题是,一旦作业完成,批处理过程就不会停止,它一直在我的eclipse和Linux盒子中运行。我手动找到并终止作业。你能帮个忙吗。当我在没有分区步骤的情况下以单线程的方式运行作业时,这工作很好。 我的作业配置:
我正在做一个项目,我们正在使用Spring Boot、Spring Batch和Camel。 关于如何在JobExecution数据可用时立即返回它,有什么想法吗?
我有以下工作要处理在一定的时间间隔或特别的基础上。 作业中的步骤如下: 我也想要用户界面,在那里我可以触发一个特别的基础上的工作,而且我应该能够提供参数从用户界面。 我想用Spring batch来完成这个任务,但它更多的是用于读->处理->写之类的工作。这里,在第一步中,我正在生成由第二步读取的数据。我不确定我是否还可以使用Spring batch来实现这个,或者有更好的方法来实现这个。
我有一个spring boot应用程序,它应该将数据库(产品)中的一个表导出为文件,所以我使用spring batch来实现这一点,我的问题是,当作业完成时,应用程序重新启动,我认为这是因为spring batch在完成后关闭了实体管理器,但我不确定 注意1:我使用作为Reader。 注意2:我正在使用从controller启动作业 注5:我发现了一个类似问题的问题,但它没有答案和关闭(重复),但
我正在尝试在后台运行作业,允许我根据某种条件或在超时发生后停止它。 我有这两块代码: