[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
其他
> 详细
Quartz集群配置
时间:
2015-01-13 01:15:52
阅读:
369
评论:
0
收藏:
0
[点我收藏+]
Quartz集群配置(100%成功)
先看看quartz的持久化基本介绍:
引用
1 大家都清楚quartz最基本的概念就是job,在job内调用具体service完成具体功能,quartz需要把每个job存储起来,方便调度,quartz存储job方式就分三种,我们最常用的也是quartz默认的是RAMJobStore,RAMJobStore顾名思义就是把job的相关信息存储在内存里,如果用spring配置quartz的job信息的话,所有信息是配置在xml里,当spirng context启动的时候就把xml里的job信息装入内存。这一性质就决定了一旦JVM挂掉或者容器挂掉,内存中的job信息就随之消失,无法持久化。另外两种方式是JobStoreTX和JobStoreCMT,暂时不讨论这两者的区别,使用这两种JobStore,quartz就会通过jdbc直连或者应用服务器jndi连接数据库,读取配置在数据库里的job初始化信息,并且把job通过java序列化到数据库里,这样就使得每个job信息得到了持久化,即使在jvm或者容器挂掉的情况下,也能通过数据库感知到其他job的状态和信息。
2 quartz集群各节点之间是通过同一个数据库实例(准确的说是同一个数据库实例的同一套表)来感知彼此的。
由上可见,我们需要创建quartz要用的数据库表,此sql文件在:quartz-1.8.6\docs\dbTables。此文件夹下有各个数据库的sql文件,mysql选择tables_mysql.sql。创建相应表。
接下来新建quartz.properties来覆盖jar包中的此文件,新的properties文件放在src的根目录下即可。下面是文件内容:
Java代码
#==============================================================
#Configure Main Scheduler Properties
#==============================================================
org.quartz.scheduler.instanceName = quartzScheduler
org.quartz.scheduler.instanceId = AUTO
#==============================================================
#Configure JobStore
#==============================================================
org.quartz.jobStore.
class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.StdJDBCDelegate
org.quartz.jobStore.tablePrefix = QRTZ_
org.quartz.jobStore.isClustered =
true
org.quartz.jobStore.clusterCheckinInterval =
20000
org.quartz.jobStore.dataSource = myDS
#==============================================================
#Configure DataSource
#==============================================================
org.quartz.dataSource.myDS.driver = com.mysql.jdbc.Driver
org.quartz.dataSource.myDS.URL = jdbc:mysql:
//192.168.20.195:3306/database?useUnicode=true&characterEncoding=UTF-8
org.quartz.dataSource.myDS.user = root
org.quartz.dataSource.myDS.password =
123456
org.quartz.dataSource.myDS.maxConnections =
30
#==============================================================
#Configure ThreadPool
#==============================================================
org.quartz.threadPool.
class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount =
10
org.quartz.threadPool.threadPriority =
5
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread =
true
可以看到除了数据源、线程池等配置外,我们指定了一个scheduler实例,实例ID为自动分配。
Java代码
#==============================================================
#Configure Main Scheduler Properties
#==============================================================
org.quartz.scheduler.instanceName = quartzScheduler
org.quartz.scheduler.instanceId = AUTO
此外,指定了集群相应配置,检查间隔为20s:
Java代码
org.quartz.jobStore.isClustered =
true
org.quartz.jobStore.clusterCheckinInterval =
20000
最后配置applicant-context.xml文件。这里特别要注意一点:
引用
MethodInvokingJobDetailFactoryBean 类中的 methodInvoking 方法,是不支持序列化的,因此在把 QUARTZ 的 TASK 序列化进入数据库时就会抛错。
所以我们要自己实现MethodInvokingJobDetailFactoryBean 的功能,这里用MyDetailQuartzJobBean 替换。
Java代码
import java.lang.reflect.Method;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.springframework.context.ApplicationContext;
import org.springframework.scheduling.quartz.QuartzJobBean;
public
class MyDetailQuartzJobBean
extends QuartzJobBean {
protected
final Log logger = LogFactory.getLog(getClass());
private String targetObject;
private String targetMethod;
private ApplicationContext ctx;
@Override
protected
void executeInternal(JobExecutionContext context)
throws JobExecutionException {
try {
logger.info(
"execute [" + targetObject +
"] at once>>>>>>");
Object otargetObject = ctx.getBean(targetObject);
Method m =
null;
try {
m = otargetObject.getClass().getMethod(targetMethod,
new Class[] {JobExecutionContext.
class});
m.invoke(otargetObject,
new Object[] {context});
}
catch (SecurityException e) {
logger.error(e);
}
catch (NoSuchMethodException e) {
logger.error(e);
}
}
catch (Exception e) {
throw
new JobExecutionException(e);
}
}
public
void setApplicationContext(ApplicationContext applicationContext) {
this.ctx = applicationContext;
}
public
void setTargetObject(String targetObject) {
this.targetObject = targetObject;
}
public
void setTargetMethod(String targetMethod) {
this.targetMethod = targetMethod;
}
终于到配置spring文件这步了
Java代码
<bean id=
"mapScheduler" lazy-init=
"false" autowire=
"no"
class=
"org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name=
"triggers">
<list>
<ref bean=
"dailyTrigger" />
<ref bean=
"billCountTrigger" />
<ref bean=
"userAcctTrigger" />
</list>
</property>
<property name=
"applicationContextSchedulerContextKey" value=
"applicationContext" />
<property name=
"configLocation" value=
"classpath:quartz.properties" />
</bean>
<bean id=
"dailyBillJob"
class=
"com.***.job.DailyBillJob" />
<bean id=
"dailyBillJobDetail"
class=
"org.springframework.scheduling.quartz.JobDetailBean">
<property name=
"jobClass">
<value>com.autelan.auteview.lib.util.MyDetailQuartzJobBean
</value>
</property>
<property name=
"jobDataAsMap">
<map>
<entry key=
"targetObject" value=
"dailyBillJob" />
<entry key=
"targetMethod" value=
"execute" />
</map>
</property>
</bean>
<bean id=
"dailyTrigger"
class=
"org.springframework.scheduling.quartz.CronTriggerBean">
<property name=
"jobDetail">
<ref bean=
"dailyBillJobDetail" />
</property>
<property name=
"cronExpression">
<value>
11
11
11 * * ?</value>
</property>
</bean>
// 转载请注明出处http://forhope.iteye.com/blog/1398990
大功告成!
Quartz集群配置
原文:http://www.cnblogs.com/Rozdy/p/4220188.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!