我正在使用带有quartz的JDBC Job store,因为在集群环境中管理作业。以下是我使用mysql的jdbc配置:
#============================================================================
# Configure Main Scheduler Properties
#============================================================================
org.quartz.scheduler.instanceName: MyScheduler
org.quartz.scheduler.instanceId: instance_one
org.quartz.scheduler.skipUpdateCheck: true
#============================================================================
# Configure ThreadPool
#============================================================================
org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount: 5
org.quartz.threadPool.threadPriority: 5
#============================================================================
# Configure JobStore
#============================================================================
org.quartz.jobStore.misfireThreshold = 60000
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate
org.quartz.jobStore.useProperties = false
org.quartz.jobStore.dataSource = quartz_cluster
org.quartz.jobStore.tablePrefix = QRTZ_
org.quartz.jobStore.isClustered = true
#============================================================================
# Configure Datasources
#============================================================================
org.quartz.dataSource.quartz_cluster.driver = com.mysql.cj.jdbc.Driver
org.quartz.dataSource.quartz_cluster.URL = jdbc:mysql://localhost:3306/quartz_cluster
org.quartz.dataSource.quartz_cluster.user = root
org.quartz.dataSource.quartz_cluster.password = root
org.quartz.dataSource.quartz_cluster.maxConnections = 5
每当我运行具有上述属性的夸脱时,我的工作开始执行,执行4次后,我得到以下异常:
[ERROR] - [2016-09-15 13:55:03,150] - [org.quartz.core.QuartzSchedulerThread] Runtime error occurred in main trigger firing loop.
java.lang.IllegalStateException: JobStore is shutdown - aborting retry
at org.quartz.impl.jdbcjobstore.JobStoreSupport.retryExecuteInNonManagedTXLock(JobStoreSupport.java:3772)
at org.quartz.impl.jdbcjobstore.JobStoreSupport.releaseAcquiredTrigger(JobStoreSupport.java:2881)
at org.quartz.core.QuartzSchedulerThread.releaseIfScheduleChangedSignificantly(QuartzSchedulerThread.java:432)
at org.quartz.core.QuartzSchedulerThread.run(QuartzSchedulerThread.java:316)
以下是我的工作细节:
newJob(MyJob.class)
.withDescription("The myjob job")
.withIdentity("job-one", "group-one")
.usingJobData(jobDataMap)
.requestRecovery(true)
.build();
以下是我的触发细节:
newTrigger()
.withIdentity("trigger-one", "group-one")
.withSchedule(cronSchedule("0/15 * * * * ?")
.withMisfireHandlingInstructionFireAndProceed())
.build();
我没有得到异常中的实际问题?
可能你可以尝试重新加载石英的数据表,我有这个例外,因为我从旧的project.reload复制旧的数据表,数据表将解决问题。你可以从tar文件link description here http://www.quartz-scheduler.org/downloads/找到sql文件