0

通过使用CronTriggerBean,我创建了两个触发器(比如触发器 A 和 B)来调用两个不同的操作。我们将项目作为 .war 放置在 2 个服务器中。我正在使用JobStoreTX进行集群。我面临的问题是我只想集群一个触发器,即 A 和触发器 B 不应该集群。有没有办法通过代码指定必须集群的触发器。我的代码如下。

<bean id="shedulerJobStoreTX" class="org.quartz.impl.jdbcjobstore.JobStoreTX>
  <property name="driverDelegateClass" value="org.quartz.impl. jdbcjobstore.oracle.OracleDelegate">
<property name="dataSource" value ="jndiDS"/>
        <property name="tablePrefix" value="someschemaName"/>
        <property name="isClustered" value="true"/>
<property name="clusterCheckinInterval" value="${someValue}"/>
    </bean>
<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">       
        <property name="triggers">
            <list>
                <ref bean="cronTrigger" />
                <ref bean="clusterCronTrigger"/>
            </list>
        </property>
    </bean>
<bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
        <property name="jobDetail" ref="runAppJob" />
        <property name="cronExpression" value="${someTimeValue1}"/>
    </bean>
    <bean id="clusterCronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
        <property name="jobDetail" ref="runClusterJob" />
        <property name="cronExpression" value="${someTimeValue2}"/>
    </bean>

嗨,我已经改进了代码,上面说的问题没有发生。PFB 的代码相同。

  <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
    <property name="triggers">
                <list>
                    <ref bean="cronTrigger" />
                    <ref bean="clusterCronTrigger"/>
                </list>
            </property>
            <property name="quartzProperties">
            <props>
              <prop key="org.quartz.jobStore.isClustered">false</prop> 
              <prop key="org.quartz.scheduler.instanceId">AUTO</prop> 
              <prop key ="org.quartz.jobStore.class">org.quartz.impl.jdbcjobstore.
   JobStoreTX </prop> 
              <prop key="org.quartz.jobStore.tablePrefix">schemaName</prop> 
              <prop key="org.quartz.jobStore.driverDelegateClass"> org.quartz.impl.jdbcjobstore.oracle.OracleDelegate</prop> 
              <prop key="org.quartz.jobStore.selectWithLockSQL"> SELECT * FROM {0}LOCKS UPDLOCK WHERE LOCK_NAME= ?</prop>
            </props>
            </property>
            <property name="dataSource" ref="fsmJndiDataSource"/> 

但是执行上述代码的问题是,当石英试图获得锁时,我得到了以下异常......” init 方法的调用失败;嵌套异常是 org.quartz.SchedulerConfigException:在作业恢复期间发生故障。 [参见嵌套异常:org.quartz.impl.jdbcjobstore.LockException:获取数据库行锁失败:ORA-00942:表或视图不存在

4

2 回答 2

3

在运行调度程序之前,您需要在数据库中创建所需的石英表。

默认石英表 sql 脚本位于 \docs\dbTables..

例如,如果您使用的是quartz 2.2.1 分发版(quartz-2.2.1-distribution.tar\quartz-2.2.1\docs\dbTables\tables_oracle)

在数据库上执行 sql 脚本并确保您看到其中创建的表参考下图

在此处输入图像描述

于 2015-10-13T12:06:33.743 回答
0

由于消息“ORA-00942:表或视图不存在”,我认为表“schemaNameLOCKS”丢失。确实,来自文档:

org.quartz.jobStore.selectWithLockSQL

必须是选择“LOCKS”表中的一行并在该行上放置锁的 SQL 字符串。如果未设置,默认为“SELECT * FROM {0}LOCKS WHERE SCHED_NAME = {1} AND LOCK_NAME = ? FOR UPDATE”,适用于大多数数据库。“{0}”在运行时被您在上面配置的 TABLE_PREFIX 替换。“{1}”替换为调度程序的名称。

于 2012-09-10T14:23:35.037 回答