批处理作业失败,因为作业执行已运行异常:此作业的作业执行已在运行



如何从主方法停止批处理作业?我正在从我的方法运行批处理作业,现在它给了我以下错误。关于如何杀死和阻止它的任何帮助?

A job execution for this job is already running: JobInstance: id=18380, version=0, Job=[myFileGenerationJob]
org.springframework.batch.core.repository.JobExecutionAlreadyRunningException: A job execution for this job is already running: JobInstance: id=18380, version=0, Job=[myFileGenerationJob]
Done
at org.springframework.batch.core.repository.support.SimpleJobRepository.createJobExecution(SimpleJobRepository.java:120)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:333)
at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:190)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157)
at org.springframework.transaction.interceptor.TransactionInterceptor$1.proceedWithInvocation(TransactionInterceptor.java:99)
at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:280)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.batch.core.repository.support.AbstractJobRepositoryFactoryBean$1.invoke(AbstractJobRepositoryFactoryBean.java:172)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:213)
at com.sun.proxy.$Proxy3.createJobExecution(Unknown Source)
at org.springframework.batch.core.launch.support.SimpleJobLauncher.run(SimpleJobLauncher.java:125)
at com.mastercard.ess.eds.CustomerFileGenerationApp.main(CustomerFileGenerationApp.java:31)

我正在使用以下代码 -

public class CustomerFileGenerationApp {
public static void main(String[] args) {
PropertyConfigurator.configure("src/main/resources/log4j.properties");
String[] springConfig = { "../META-INF/spring/customer-file-generation-job.xml"};
ApplicationContext context = new FileSystemXmlApplicationContext(springConfig);
JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");
Job job = (Job) context.getBean("customerFileGenerationJob");
JobParameters jobParameters = new JobParametersBuilder().addString("runMode", "ABCD").toJobParameters();
try {
JobExecution execution = jobLauncher.run(job, jobParameters);
System.out.println("Exit Status : " + execution.getStatus());
} catch (Exception e) {
System.out.println(e.getMessage());
e.printStackTrace();
}
System.out.println("Done");
}
}

不幸的是,我不知道通过使用java代码来处理该异常。 但是,您可以通过使用某些查询更新相关的批处理元表数据来管理该异常。

您应该检查两个表, batch_step_execution,batch_job_execution。 (我假设您已经创建了它们,因为Spring Batch将它们提供给几乎所有类型的数据库。

如果这些表具有已开始(正在(和未完成的作业, 重新启动服务器时,可能会遇到上述异常。

因此,首先,您可以通过执行下面的查询来检查正在运行的作业是否存在。

SELECT  STEP_EXECUTION_ID
, JOB_EXECUTION_ID
, STEP_NAME
, STATUS
, EXIT_CODE
, bse.*
FROM batch_step_execution bse
WHERE 1=1
AND status IN ('STARTED', 'STARTING')
AND exit_code NOT IN ('COMPLETED', 'FAILED')
ORDER BY start_time desc
;
SELECT bje.JOB_EXECUTION_ID
, bji.JOB_NAME
, bje.JOB_INSTANCE_ID
, bje.STATUS
, bje.EXIT_CODE
, timediff(bje.CREATE_TIME, NOW()) 
, bje.*
FROM batch_job_execution bje
INNER JOIN batch_job_instance bji
ON bje.job_instance_id = bji.job_instance_id
WHERE 1=1
AND status IN ('STARTED', 'STARTING')
AND exit_code NOT IN ('COMPLETED', 'FAILED')
ORDER BY bje.create_time desc
;

其次,如果上面有行, 您可以通过执行以下查询将这些作业更新为"已完成"状态。

UPDATE 
batch_step_execution 
SET END_TIME = now()
,LAST_UPDATED = now() 
,STATUS = 'COMPLETED' 
,EXIT_CODE = 'FAILED' 
WHERE 
STEP_EXECUTION_ID in (
select STEP_EXECUTION_ID 
from batch_step_execution bse 
where 1=1
and status not in ('COMPLETED', 'FAILED')
or EXIT_CODE not in ('COMPLETED', 'FAILED') 
)
;
UPDATE 
BATCH_JOB_EXECUTION 
SET 
END_TIME = now() 
,LAST_UPDATED = now() 
,STATUS = 'COMPLETED' 
,EXIT_CODE = 'FAILED' 
WHERE 
JOB_EXECUTION_ID in (
select bje.JOB_EXECUTION_ID
from batch_job_execution bje 
where 1=1
and (status not in ('COMPLETED', 'FAILED'))
or (EXIT_CODE not in ('COMPLETED', 'FAILED'))
)
;

第三,请重新启动服务器。 就我而言,当我遇到JobExecutionAlreadyRunningException时,它可以工作。

谢谢。

最新更新