Spring 配置 quartz任务调度遇到的问题和解决方法

Spring版本:3.2.13.RELEASE

quartz版本:2.2.1

 

1. 基本配置

(1)配置自己写的任务类

 (2)配置JobDetail


		
			
		
		
			scan
		
	

 targetObject指定任务对象,targetMethod指定对象执行方法

(3)配置触发器


		
			
		
		
			0 0/1 * * * ?
		
	

 这里 0 0/1 * * * ? 表示每一分钟执行一次,关于调用时间的具体配置可以参照

http://jingyan.baidu.com/article/0f5fb099cc244d6d8234ea6b.html

(4)配置总管理类


		
			
				
			
		
	

 lazy-init="false"表示容器启动就开始执行调度任务, 这里可以配置多个触发器,可以统一管理

 

2. 出现的问题

按照上述配置后,写了Junit测试运行,发现出现错误:

(1)

Cannot find class [org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean] for bean with name

这个异常就是上面这个类找不到,开始我到spring-context.jar中去找,虽然有org.springframework.scheduling这个包,但是却没有quartz,后来上网查了好久才知道,上面这个类在spring-contex-support这个包中(以前spring用一个jar,后来分成了多个jar包),引入进来就对了。

(2)

解决了上面的问题后,又出现一个新的错误:

java.lang.IncompatibleClassChangeError: class org.springframework.scheduling.quartz.CronTriggerBean has interface org.quartz.CronTrigger as super class  

这是因为版本不兼容引起的,解决的办法是:

1. 降低quartz到1.x版本

2. 根据spring的建议将原来的xxxTriggerBean替换成xxxTriggerFactoryBean,这里就是将配置中的第三步配置触发器类CronTriggerBean换成CronTriggerFactoryBean:


		
			
		
		
			0 0/1 * * * ?
		
	

 (3) 

解决了上面两个问题后,发现又有错误:

Table 'database.qrtz_locks' doesn't exist

这个错误看起来匪夷所思。。。

 参考:

http://blog.sina.com.cn/s/blog_6151984a0100o42e.html

SchedulerFactoryBean试图访问数据库获取quartz的一些管理表信息,自然访问数据库时需要注入dataSource bean,当缺省autowire为no,则没有dataSource bean被注入,quartz会认为项目没连数据库,会BYPASS这个访问管理表的功能. 当你配置了default-autowire=byName时,dataSource bean被自动注入,这时quartz认为项目既然能连到数据库,就想当然的认为对应的那些表一定存在,没找到时就出异常.

 

 

解决办法:

1.  去掉default-autowire=byName(这种方法估计不是很愿意,得损失很多便利)

2. 在数据库中创建相应的数据表(这种需要创建很多表,而且建这些表可能我们暂时也用不到)

3. 在SchedulerFactoryBean这个bean配置中关掉autoware,加入autorware=“no”(这个解决方法好!):


		
			
				
			
		
	

 

你可能感兴趣的:(Spring)