我使用quartz 2.2.1和mysql进行作业存储,为创建新作业,它使用旧作业数据覆盖mysql表中的表内容。 没有错误。
这是我的代码:
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.Trigger;
import org.quartz.TriggerBuilder;
import org.quartz.impl.StdSchedulerFactory;
import org.quartz.JobDetail;
import static org.quartz.JobBuilder.newJob;
import static org.quartz.SimpleScheduleBuilder.simpleSchedule;
public class OwnScheduler {
public static void main(String[] args) throws InterruptedException, SchedulerException{
Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
try {
// Grab the Scheduler instance from the Factory
// and start it off
scheduler.start();
JobDetail job1 = newJob(FetchJob.class).storeDurably(true).withIdentity("test4","Group4").build();
Trigger trigger = (Trigger) TriggerBuilder.newTrigger()
.withIdentity("Trigger2", "Group4").startNow()
.withSchedule(simpleSchedule()
.withIntervalInSeconds(2))
.build();
Thread.sleep(90L * 10L);
scheduler.scheduleJob(job1, (Trigger) trigger);
scheduler.shutdown();
} catch (Exception se) {
se.printStackTrace();
}
}
}
和我的属性文件:
org.quartz.scheduler.instanceName = MyScheduler
org.quartz.scheduler.instanceId = NON_CLUSTERED
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 50
org.quartz.scheduler.jobFactory.class = org.quartz.simpl.SimpleJobFactory
org.quartz.jobStore.useProperties = true
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreCMT
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate
org.quartz.jobStore.tablePrefix = QRTZ_
org.quartz.jobStore.dataSource = quartz
org.quartz.jobStore.nonManagedTXDataSource = quartz
org.quartz.dataSource.quartz.driver = com.mysql.jdbc.Driver
org.quartz.dataSource.quartz.URL = jdbc:mysql://localhost/quartz
org.quartz.dataSource.quartz.user = root
org.quartz.dataSource.quartz.password = password
我做错了什么。
为每个作业创建表数据被新作业详细信息覆盖。 谢谢你的关注。
答案 0 :(得分:0)
你是如何调用此代码的?您有一个主要条目进入您的JVM运行时,您在其中初始化Quartz,作业和触发器,您安排作业,然后关闭调度程序。为什么不按照某些条件开始计划并退出?