石英中的方法 Scheduler.getCurrentlyExecutingJobs() 显然不是集群感知的。人们使用什么方法来获取所有正在执行的作业的列表?
John
问问题
4755 次
2 回答
4
似乎不会很快对调度机制进行彻底改革。
因此,这就是我直接检查表格的方式 - 如果需要,请添加组支持:
class QuartzClusterJobStatusService
{
def quartzScheduler
boolean isJobRunning(String job) {
return isJobRunningHere(job) || isJobRunningElsewhere(job)
}
boolean isJobRunningHere(String job) {
for (JobExecutionContext j : quartzScheduler.getCurrentlyExecutingJobs()) {
if (new JobKey(job,"GRAILS_JOBS").equals(j.jobDetail.key)) {
return true
}
}
return false
}
boolean isJobRunningElsewhere(String job) {
JobStoreSupport js = quartzScheduler.sched.resources.jobStore
if (!js.isClustered()) {
return false
}
Connection conn = DBConnectionManager.getInstance().getConnection(js.getDataSource());
PreparedStatement stmt = null
try {
stmt = conn.prepareStatement("SELECT 1 FROM " + js.getTablePrefix() + "FIRED_TRIGGERS where JOB_NAME = ?")
stmt.setString(1, job)
ResultSet rs = stmt.executeQuery()
return rs.next()
} finally {
if (stmt != null)
stmt.close()
}
}
}
于 2013-06-21T18:51:15.917 回答
-1
我假设一种方法是直接访问数据库,尽管它有点冒险,因为 API 完全处理了它。
为此,他们的 Jira 中有一个问题。他们的结论是,如果他们想要满足集群意识,您需要彻底检查调度机制。
于 2009-10-09T06:40:39.550 回答