gpt4 book ai didi

java - 使用 CronTrigger 和 MySQL 做调度器时出现 ClassNotFoundException

转载 作者:行者123 更新时间:2023-11-29 05:41:17 24 4
gpt4 key购买 nike

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%,这是相当高的。但是,我不确定我的 quartz 文件是否写入正确。下面是写入的 quartz 文件。

配置主调度器属性##

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

配置线程池

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

配置JobStore

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 = password
org.quartz.dataSource.myDS.maxConnections 5

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

最佳答案

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

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

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

从 quartz 表中手动删除是有风险的,通常是不可取的。您可能不知道哪些行属于作业触发器/作业。

关于java - 使用 CronTrigger 和 MySQL 做调度器时出现 ClassNotFoundException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17480452/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com