Java Quartz запланированное задание-запретить одновременное выполнение задания

Я использую задание Quartz для выполнения определенных задач.

Я также планирую его выполнение в своем основном классе приложений, и то, что я пытаюсь выполнить, не позволяет выполнять одновременные экземпляры этого задания.

таким образом, планировщик должен выполнить задание, только если его предыдущий экземпляр завершен.

вот мой класс работы:

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 .... <<<<<<<<<<<<<<<<<<<<");

    }
}

поэтому в основном классе моего приложения я начинаю планировщик:

...
//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);

}

Я хотел бы запретить планировщику запускать второй экземпляр MainJob, если другой все еще работает ...

3 ответов


просто использовать @DisallowConcurrentExecution Аннотация В верхней части класса заданий.

посмотреть этот чиновник пример или это учебник о параллельном выполнении задания.


вы можете реализовать StatefulJob или аннотации DisallowConcurrentExecution


@DissallowConcurrentExecution может выполнять вашу работу, но, пожалуйста, учтите, что это только предотвратит запуск вашего класса дважды на одном узле.

пожалуйста, смотрите комментарий @ReneM в Quartz 2.2 мульти планировщик и @DisallowConcurrentExecution