scheduler.getCurrentlyExecutingJobs()在大多数情况下应该可以工作。但是请记住不要在Job类中使用它,因为它使用ExecutingJobsManager(a
JobListener)将正在运行的作业放到HashMap中,该HashMap在作业类之前运行,因此使用此方法检查作业是否正在运行肯定会返回true。一种简单的方法是检查点火时间是否不同:
public static boolean isJobRunning(JobExecutionContext ctx, String jobName, String groupName) throws SchedulerException { List<JobExecutionContext> currentJobs = ctx.getScheduler().getCurrentlyExecutingJobs(); for (JobExecutionContext jobCtx : currentJobs) { String thisJobName = jobCtx.getJobDetail().getKey().getName(); String thisGroupName = jobCtx.getJobDetail().getKey().getGroup(); if (jobName.equalsIgnoreCase(thisJobName) && groupName.equalsIgnoreCase(thisGroupName) && !jobCtx.getFireTime().equals(ctx.getFireTime())) { return true; } } return false;}另请注意,此方法不支持群集。也就是说,它将仅返回当前在此Scheduler实例中执行的Job,而不返回整个集群。如果您在集群中运行Quartz,它将无法正常工作。



