我遇到了以下问题:我有一个带有石英插件的grails应用程序和一个持久存储(Oracle)。我的工作类有一个空的触发器块,如下所示:
class VodServerJob {
static triggers = {}
def volatility = false;
def durability = true;
def concurrency = false;
def group = "MyGroup"
def execute(context) { }
}
...但是我在编程时以编程方式添加触发器(让用户安排作业的启动时间)。当我关闭应用程序时,触发器仍然在数据库中。但是在启动时,触发器被移除,从而破坏了持久存储的重点。
我的配置如下:
quartz {
autoStartup = true
jdbcStore = true
waitForJobsToCompleteOnShutdown = true
}
environments {
test { quartz { autoStartup = false } }
}
我的属性如下:
#============================================================================
# Configure ThreadPool
#============================================================================
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 25
org.quartz.threadPool.threadPriority = 5
#============================================================================
# Configure JobStore
#============================================================================
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.oracle.OracleDelegate
org.quartz.jobStore.useProperties = false
org.quartz.jobStore.dataSource = myDS
org.quartz.jobStore.tablePrefix = QRTZ_
#============================================================================
# Configure Datasources
#============================================================================
org.quartz.dataSource.myDS.driver = oracle.jdbc.driver.OracleDriver
org.quartz.dataSource.myDS.URL = jdbc:oracle:thin:@172.27.5.18:1521:dcrm
org.quartz.dataSource.myDS.user = <hidden, but valid>
org.quartz.dataSource.myDS.password = <hidden, but valid>
org.quartz.dataSource.myDS.maxConnections = 5
org.quartz.dataSource.myDS.validationQuery=select 0 from dual
根据我能看到的一切,这应该允许数据库持久性,然而,它在启动时被删除。任何人都有任何想法?
答案 0 :(得分:3)
在这个问题上找到答案。默认情况下,触发器设置为volatile
,这意味着它们在启动时被删除。只需将触发器的volatility
设置为false
,如下所示,您的触发器将无限期保留。
trigger.setVolatility(false);
否则,它们会被擦除。