1

java.lang.ClassNotFoundException在 Java 中使用 CronTrigger 和 MySQL 做调度程序时

我目前正在开发一个项目,该项目需要调度程序从服务器从 MySQL 数据库下载数据并将其放入存储在固定目录中的文本文件中。我正在使用 CronTrigger 和调度程序来完成此任务,我的项目将驻留在 Tomcat 版本 6.0/webapps 目录中。但是,我在运行程序时遇到了这个问题。

Jul 5, 2013 3:10:00 PM org.quartz.impl.jdbcjobstore.JobStoreSupport triggerFired
SEVERE: Error retrieving job, setting trigger state to ERROR.
org.quartz.JobPersistenceException: Couldn't retrieve job because a required class was not found: bgoc.dwgScheduler.dwg_QuartzAutoDownloadJob [See nested exception: java.lang.ClassNotFoundException: bgoc.dwgScheduler.dwg_QuartzAutoDownloadJob]**<br>

at org.quartz.impl.jdbcjobstore.JobStoreSupport.retrieveJob(JobStoreSupport.java:1328)<br>
at org.quartz.impl.jdbcjobstore.JobStoreSupport.triggerFired(JobStoreSupport.java:2789)<br>
at org.quartz.impl.jdbcjobstore.JobStoreSupport$37.execute(JobStoreSupport.java:2757)<br>
at org.quartz.impl.jdbcjobstore.JobStoreSupport.executeInNonManagedTXLock(JobStoreSupport.java:3662)<br>
at org.quartz.impl.jdbcjobstore.JobStoreSupport.triggerFired(JobStoreSupport.java:2751)<br>
at org.quartz.core.QuartzSchedulerThread.run(QuartzSchedulerThread.java:313)<br>
Caused by: java.lang.ClassNotFoundException: bgoc.dwgScheduler.dwg_QuartzAutoDownloadJob <br>
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)<br>
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)<br>
at org.quartz.simpl.InitThreadContextClassLoadHelper.loadClass(InitThreadContextClassLoadHelper.java:74)<br>
at org.quartz.simpl.CascadingClassLoadHelper.loadClass(CascadingClassLoadHelper.java:118)<br>
at org.quartz.impl.jdbcjobstore.StdJDBCDelegate.selectJobDetail(StdJDBCDelegate.java:897)<br>
at org.quartz.impl.jdbcjobstore.JobStoreSupport.retrieveJob(JobStoreSupport.java:1316)<br>

我确信我的 java 代码不是问题,因为这个错误不会一直发生。但是,它有30%的发生率,这是相当高的。但是,我不确定我的石英文件是否正确写入。下面是编写的石英文件。

配置主调度程序属性##

org.quartz.scheduler.instanceName = DefaultQuartzScheduler
org.quartz.scheduler.instanceId = 一

配置线程池

org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 5
org.quartz.threadPool.threadPriority = 4

配置作业存储

org.quartz.jobStore.misfireThreshold = 5000
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate
org.quartz.jobStore.dataSource = myDS
org.quartz.jobStore.tablePrefix = QRTZ_

配置数据源

org.quartz.dataSource.myDS.driver = com.mysql.jdbc.Driver
org.quartz.dataSource.myDS.URL = jdbc:mysql://localhost:3307/QRTZ_BIS
org.quartz.dataSource.myDS.user = root
org .quartz.dataSource.myDS.password = 密码
org.quartz.dataSource.myDS.maxConnections 5

谁能帮我解决这个问题?如果您想了解更多信息,请发帖,我会尽快提供。

4

2 回答 2

2

我也有同样的情况。这是因为我在版本发布期间删除了以前使用的作业。我没有计算留在数据库中的几个触发器(不是 cron,而是简单的延迟触发器)。那些试图执行但失败了,因为他们的工作已经被删除了。

我最终做的是用空的执行方法主体将工作放回原处(记录它被调用的事实)。

这样,在使用 empty 方法部署版本后,触发器可以毫无问题地触发,quartz 不会抱怨这一点。在下一个版本中,您也可以删除空作业。

从石英表中手动删除是有风险的,通常不建议这样做。您可能不知道哪些行属于作业触发器/作业。

于 2018-07-05T12:55:03.550 回答
1

类加载器抱怨类bgoc.dwgScheduler.dwg_QuartzAutoDownloadJob丢失。

这堂课是你的吗?你检查过这个类是否在类路径上吗?

也许这个类不是必需的,但其他一些类或配置可能正在导入它。

于 2013-07-05T03:07:31.880 回答