Java Quartz scheduled Job - disallow concurrent execution of Job

天大地大妈咪最大 提交于 2019-11-26 09:03:22

问题


I am using a Quartz Job for executing specific tasks.

I am also scheduling its execution in my Main application class and what i am trying to accomplish is not to allow simultaneous instances of this job to be executed.

So the scheduler should only execute the job if its previous instance is finished.

Here is my Job class:

public class MainJob implements Job {

static Logger log = Logger.getLogger(MainJob.class.getName());

@Override
public void execute(JobExecutionContext arg0) throws JobExecutionException {

    GlobalConfig cfg = new GlobalConfig();

    ProcessDicomFiles processDicomFiles = new ProcessDicomFiles();  
    ProcessPdfReportFiles processPdf = new ProcessPdfReportFiles();

    try {

            log.info(\"1. ---- SCHEDULED JOB -- setStudiesReadyToProcess\");
            processDicomFiles.setStudiesReadyToProcess();

            log.info(\"2. ---- SCHEDULED JOB --- distributeToStudies\");
            processDicomFiles.distributeToStudies(cfg.getAssocDir());                

            ...

            //process any incoming PDF file
            log.info(\"11. ---- SCHEDULED JOB --- processPdfFolder\");
            processPdf.processPdfFolder();

        } catch (Exception ex) {
            Logger.getLogger(FXMLDocumentController.class.getName()).log(Level.ERROR, null, ex);
        }

    log.info(\">>>>>>>>>>> Scheduled Job has ended .... <<<<<<<<<<<<<<<<<<<<\");

    }
}

So in my application\'s main class i am starting the scheduler:

...
//start Scheduler
    try {             
        startScheduler();
    } catch (SchedulerException ex) {
        log.log(Level.INFO, null, ex);
    }
...

public void startScheduler () throws SchedulerException {

        //Creating scheduler factory and scheduler
        factory = new StdSchedulerFactory();
        scheduler = factory.getScheduler();

        schedulerTimeWindow = config.getSchedulerTimeWindow();

        JobDetailImpl jobDetail = new JobDetailImpl();
        jobDetail.setName(\"First Job\");
        jobDetail.setJobClass(MainJob.class);

        SimpleTriggerImpl simpleTrigger = new SimpleTriggerImpl();
        simpleTrigger.setStartTime(new Date(System.currentTimeMillis() + 1000));
        simpleTrigger.setRepeatCount(SimpleTrigger.REPEAT_INDEFINITELY);
        simpleTrigger.setRepeatInterval(schedulerTimeWindow);
        simpleTrigger.setName(\"FirstTrigger\");

        //Start scheduler
        scheduler.start();
        scheduler.scheduleJob(jobDetail,simpleTrigger);

}

I would like to prevent scheduler from starting a second MainJob instance if another one is still running ...


回答1:


Just use the @DisallowConcurrentExecution Annotation on top of the Job class.

See this official example or this tutorial about concurrent job execution.




回答2:


You can implement StatefulJob or annotate DisallowConcurrentExecution




回答3:


@DisallowConcurrentExecution can do your job but please consider that it would only prevent your class from being run twice on the same node.

Please see @ReneM comment in Quartz 2.2 multi scheduler and @DisallowConcurrentExecution



来源:https://stackoverflow.com/questions/28879397/java-quartz-scheduled-job-disallow-concurrent-execution-of-job

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!