gpt4 book ai didi

java - 如何从 RAMJobStore 迁移到 JobStoreCMT,以便在 Seam 中持久化 Quartz 作业

转载 作者:行者123 更新时间:2023-11-30 09:44:48 35 4
gpt4 key购买 nike

我正在尝试获取在 JBoss Seam 2.2.0.GA 中运行的 Quartz 调度程序的简单示例。使用 RAMJobStore 设置一切正常,但将商店从

org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore

org.quartz.jobStore.class org.quartz.impl.jdbcjobstore.JobStoreCMT
org.quartz.jobStore.driverDelegateClass org.quartz.impl.jdbcjobstore.PostgreSQLDelegate
org.quartz.jobStore.useProperties false
org.quartz.jobStore.dataSource quartzDatasource
## FIXME Should be a different datasource for the non managed connection.
org.quartz.jobStore.nonManagedTXDataSource quartzDatasource
org.quartz.jobStore.tablePrefix qrtz_
org.quartz.dataSource.quartzDatasource.jndiURL java:/quartzDatasource

允许调度程序启动,但是作业之前被触发并以正确的时间间隔运行,现在它根本不运行。 quartz 数据库中也没有任何内容。

我知道 nonManagedTXDataSource 不应该与托管数据源相同,但我遇到了 Quartz 无法找到数据源的问题,即使之前有一条消息报告它被成功绑定(bind)(这可能会在一个单独的问题中被问到)。使用相同的数据源可以使服务无错误地启动。

我的 components.xml 文件包含以下内容:

<event type="org.jboss.seam.postInitialization"> 
<action execute="#{asyncResultMapper.scheduleTimer}"/>
</event>
<async:quartz-dispatcher/>

并且 ASyncResultMapper 具有以下内容:

@In
ScheduleProcessor processor;
private String text = "ahoy";
private QuartzTriggerHandle quartzTriggerHandle;

public void scheduleTimer() {
String cronString = "* * * * * ?";
quartzTriggerHandle = processor.createQuartzTimer(new Date(), cronString, text);
}

和ScheduleProcessor如下:

@Name("processor")
@AutoCreate
@Startup
@Scope(ScopeType.APPLICATION)
public class ScheduleProcessor {

@Asynchronous
public QuartzTriggerHandle createQuartzTimer(@Expiration Date when, @IntervalCron String interval, String text) {
process(when, interval, text);
return null;
}

private void process(Date when, String interval, String text) {
System.out.println("when = " + when);
System.out.println("interval = " + interval);
System.out.println("text = " + text);
}
}

日志显示服务已启动,但与作业无关:

INFO  [QuartzScheduler] Quartz Scheduler v.1.5.2 created.
INFO [JobStoreCMT] Using db table-based data access locking (synchronization).
INFO [JobStoreCMT] Removed 0 Volatile Trigger(s).
INFO [JobStoreCMT] Removed 0 Volatile Job(s).
INFO [JobStoreCMT] JobStoreCMT initialized.
INFO [JobStoreCMT] Freed 0 triggers from 'acquired' / 'blocked' state.
INFO [JobStoreCMT] Recovering 0 jobs that were in-progress at the time of the last shut-down.
INFO [JobStoreCMT] Recovery complete.
INFO [JobStoreCMT] Removed 0 'complete' triggers.
INFO [JobStoreCMT] Removed 0 stale fired job entries.
INFO [QuartzScheduler] Scheduler FlibScheduler$_NON_CLUSTERED started.

我敢肯定这可能是我遗漏的一些微不足道的事情,但我无法在任何地方的论坛中找到解决方案。

最佳答案

最后我自己解决了这个问题。 JobStoreCMT 版本未启动和触发作业的问题是由于缺少 @Transactional(感谢 tair),更重要的是需要升级 Quartz。一旦 Quartz 升级到 1.8.5,错误消息就变得更有用了。

关于java - 如何从 RAMJobStore 迁移到 JobStoreCMT,以便在 Seam 中持久化 Quartz 作业,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7697706/

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