这里提供三套解决方案
方案1:
Properties props = new Properties();
props.put("org.quartz.threadPool.threadCount", threadCount);
props.put("org.quartz.scheduler.instanceName", instanceName);
StdSchedulerFactory factory = new StdSchedulerFactory();
factory.initialize(props);
Scheduler scheduler = factory.getScheduler();
scheduler.start();
将org.quartz.threadPool.threadCount线程数设置为1,此时因为线程池中只有一个线程,当一个job在执行中并未执行完,线程池中并无可用线程,其他job会处于等待状态,从而实现串行执行
方案2:
通过在job上增加**@DisallowConcurrentExecution**注解(ps:这个注解在org.quartz包中)
@DisallowConcurrentExecution
public class DrawerBalanceGrepJob implements Job { ........ }
方案3:spring和quartz结合
****