Quartz Schduler在Jobstore表中覆盖作业数据

时间:2015-09-28 10:34:35

标签: java mysql quartz-scheduler

我使用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

我做错了什么。

为每个作业创建表数据被新作业详细信息覆盖。 谢谢你的关注。

1 个答案:

答案 0 :(得分:0)

你是如何调用此代码的?您有一个主要条目进入您的JVM运行时,您在其中初始化Quartz,作业和触发器,您安排作业,然后关闭调度程序。为什么不按照某些条件开始计划并退出?