`
iluoxuan
  • 浏览: 582154 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

spring+ Quartz冲突问题解决

    博客分类:
  • java
 
阅读更多

关键字: spring Quartz

 

Exception in thread "main" java.lang.NoSuchMethodError: 
org.apache.commons.collections.SetUtils.orderedSet(Ljava/util/Set;)Ljava/util/Set;
 at org.quartz.JobDetail.<init>(JobDetail.java:85)

这个问题困扰了我N久,幸好看到了这篇文章,写的很详细,转载下.

 

假设你是一个J2EE程序员,你正在使用struts2+spring2+hibernate3的时尚标准组合来开发一个项目。某天,你的项目经理告诉 你,当前项目需要开发一个新功能,需要系统来定时来执行一段代码,比如每天大半夜定时进行前一天的数据统计并且插入数据库。如果你部署的系统是Linux 并且你熟悉crontab而且你打算那么麻烦地去干,我当然没话可说。否则在你google和baidu了一会儿之后,你必然会想到可以使用著名的 quartz来和spring集成起来做这件事。 

比如,先把需要干的活儿写在一个类的一个方法里面:

Java代码  收藏代码
  1. public class ScheduleWorker {  
  2. public void doDailyWork() {  
  3. System.out.println("今日统计完毕!");  
  4. }  
  5. }   
 


然后,配置spring的applicationContext.xml如下:

Xml代码  收藏代码
  1. <bean name="scheduleWorker" class="test.ScheduleWorker">  
  2. </bean>  
  3. <bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">  
  4. <property name="targetObject" ref="scheduleWorker" />  
  5. <property name="targetMethod" value="doDailyWork" />  
  6. <property name="concurrent" value="false" />  
  7. </bean>  
  8.   
  9. <bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">  
  10. <property name="jobDetail" ref="jobDetail" />  
  11. <!-- 每天零点 -->  
  12. <property name="cronExpression">  
  13. <value>0 0 * * * ?</value>  
  14. </property>  
  15. </bean>  
  16.   
  17. <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean" autowire="no">  
  18. <property name="triggers">  
  19. <list>  
  20. <ref bean="cronTrigger" />  
  21. </list>  
  22. </property>  
  23. </bean>   
 

然 后编译上传(别忘了上传更新的applicationContext.xml还有quartz.jar,一般都在spring解开的包的 lib/quartz目录下面)。你重新启动你的tomcat(也可能是resin或者其他什么东西),然后,不出意外地,发现如下错误: 



ERROR [org.springframework.web.context.ContextLoader] - Context initialization failed 
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'jobDetail' defined in ServletContext resourc 
e [/WEB-INF/classes/applicationContext-service.xml]: Invocation of init method failed; nested exception is java.lang.NoSuchMethodErr 
or: org.apache.commons.collections.SetUtils.orderedSet(Ljava/util/Set;)Ljava/util/Set; 
如果你经验比较丰富,你会去找你部署的服务器的WEB-INF/lib下面是不是存在commons-collections的jar包,然后你很惊奇地发现它的确在那里,你会很困惑。 

如 果你经验十分丰富,你知道了commons-collections.jar的确存在于classpath里面,你知道引起 NoSuchMethodErr的原因很可能是部署服务器上的commons-collections.jar的版本过低,在quartz调用的时候不存 在而导致的,于是你会去检查WEB-INF/lib下面的commons-collections.jar的版本,然后你还是会很惊奇地发现它的版本是 3.2,并且在这个jar包里面的确存在org.apache.commons.collections.SetUtils这个类,并且方法 orderedSet也存在,你还是会很困惑。 

如果你经验非常丰富,你知道了引起上面这种情况的原因是系统的classloader 先加载了其他地方低版本的commons-collections里面的 org.apache.commons.collections.SetUtils类,导致WEB-INF/lib下面的commons- collections.jar里面的同名类没有被加载所导致的。于是你就到处去找另外的commons-collections.jar,在WEB- INF/lib你可能会找到一个,包括common/lib等等地方,如果你是jdk6,你还有可能在jdk的ext目录下找到。删掉老版本的 commons-collections.jar,重启tomcat,发现问题依旧,你继续找。但是皇天不负有心人,你啥都没找到,整个jdk和整个 tomcat下面,你整个搜索了一番,只有这么一个commons-collections.jar。你依然会很困惑。 

不卖关子了。解决问题的办法:删除WEB-INF/lib/checkstyle-all.jar,重新启动tomcat,问题解决。 

在 hibernate3的lib目录下,存在commons-collections-2.1.1.jar和checkstyle-all.jar,一般我 们都是直接上传到WEB-INF/lib,前者不必说,版本太老而被classloader先加载了,按说删了问题应该解决了,但是为什么必须删掉 checkstyle-all.jar问题才能正式解决呢。拿WinRAR打开checkstyle-all.jar一看你就知道了,里面赫然有 org.apache.commons.collections.SetUtils这个类,并且,它是老版本的! 

这也太可恶了,明明 叫checkstyle-all.jar,里面为啥还包含commons-collections的东西……而且还是老调牙的版本。另外,如果你觉得 checkstyle-all.jar或许还有点什么用处,可以用WinRAR解开之后把commons-collections的包和类去掉,然后重新 打包上传。 

其实问题的根源在于:hibernate3使用老版本(2.1.1)的commons-collections及包含它的 checkstyle-all.jar,而spring2.5使用新版本(3.2)的commons-collections以及需要3.2版本 commons-collections的quartz。

分享到:
评论

相关推荐

    11-Spring+Quartz定时任务最简集群版1

    【Spring+Quartz定时任务最简集群版1】是一个基于Spring和Quartz的定时任务解决方案,用于在分布式环境中实现任务的自动调度。本项目作为Dubbo工程的一部分,它依赖于Dubbo的一些公共组件,同时也提供了将定时任务...

    配置Spring+quartz定时器.docx

    - **依赖版本**:确保使用的Spring和Quartz版本之间没有冲突,尤其是在Maven项目中。 - **并发控制**:如果任务可能并发执行,需考虑线程安全问题。 - **异常处理**:在编写定时任务时,需要妥善处理可能出现的异常...

    spring+quartz 精简版jar包 含log4j

    Spring和Quartz是两个非常重要的组件,它们分别在应用管理和定时任务调度方面发挥着重要作用。在这个精简版的jar包中,我们看到这六个核心文件,它们包含了运行Spring与Quartz的基本依赖,同时集成了log4j用于日志...

    ssm框架+quartz2.2Jar包

    1. **配置Spring**:在Spring的配置文件中添加Quartz的配置,包括SchedulerFactoryBean,JobDetail和Trigger,以便于Spring管理Quartz的实例。 2. **定义Job类**:创建实现`org.quartz.Job`接口的类,定义实际要...

    quartz整合springbatch动态集群定时实现mysql参考

    Quartz和Spring Batch是两种非常重要的Java开源框架,它们在企业级应用开发中扮演着重要角色。Quartz主要用于任务调度,而Spring Batch则专注于批量处理。在这个“quartz_springbatch_dynamic”项目中,我们将看到...

    spring2与quartz在Web整合

    Spring 2 和 Quartz 是两个在 Java Web 开发中非常重要的框架。Spring 是一个全面的开源应用框架,...对于出现问题的整合,开发者可以通过分析源码、查看日志和调试来定位和解决问题,进一步提升开发效率和应用稳定性。

    spring整合quartz常见问题

    - **方案二**虽然也可以解决问题,但需要开发者额外关注对象的序列化逻辑,增加了开发的复杂度。 ##### 3. 集群环境下实例恢复警告 **问题描述**: 在使用Quartz集群功能时,可能会遇到这样的警告:“这个调度器...

    spring集成quartz集群配置

    在IT行业中,Spring框架是Java应用开发中的基石,而Quartz则是广泛使用的任务调度库,尤其适用于企业级应用。本文将深入探讨如何在Spring环境中集成Quartz以实现集群配置,以便于在分布式环境中进行高效的任务调度。...

    完美解决多应用服务器负载均衡环境下spring quartz同一定时任务重复执行问题

    综上所述,解决Spring Quartz在负载均衡环境下的重复执行问题,需要综合运用Quartz的集群特性、数据库Job Store、公平调度以及应用层面的设计策略。通过这些方法,可以确保在多服务器环境中,定时任务的执行有序且...

    spring 配置quartz需要的jar包

    在Java开发中,Spring框架与Quartz库的集成可以实现灵活且强大的定时任务管理。Spring提供了与Quartz的无缝整合,使得我们可以利用Spring的IoC(Inversion of Control)和AOP(Aspect-Oriented Programming)特性来...

    quartz.*整合struts2、spring一个的demo

    在整合过程中,可能遇到的常见问题包括版本兼容性、依赖冲突以及配置错误。确保所有使用的库(如Quartz、Struts2、Spring及其相关依赖)的版本相互兼容是非常重要的。如果程序报错,通常需要检查是否存在缺失的jar包...

    spring-quartz所需jar包

    在实际项目中,确保所有依赖的版本相匹配是非常重要的,以避免潜在的冲突和问题。 综上所述,Spring Quartz所需jar包集合包含了Spring框架、Quartz调度器、以及其他支持类库,共同构建了一个完整的定时任务解决方案...

    Spring集群整合Quartz

    - 监控:使用Quartz提供的监控工具,或集成第三方监控工具(如Prometheus、Grafana),实时查看任务执行状态,及时发现并解决问题。 总结来说,Spring与Quartz的整合可以提供强大且灵活的定时任务功能。在集群环境...

    Quartz2.2.1和Spring3.1.1集群

    通过设置相同的`org.quartz.scheduler.instanceId`属性为"AUTO",Quartz会自动生成唯一的实例ID,避免冲突。 3. **集群配置**:在`org.quartz.properties`文件中,需要设置`org.quartz.jobStore.isClustered=true`...

    spring quartz集群配置

    9. **集群同步机制**:Quartz通过`StatefulJobs`和`MisfireInstructions`来处理任务的同步问题,确保在节点间的任务不冲突。 10. **测试与监控**:部署后,定期检查集群的健康状况,监控每个节点的心跳,确保任务...

    spring-quartz

    4. **资源管理**:Spring的依赖注入机制可以帮助更好地管理Quartz所需的资源,减少资源冲突的可能性。 #### 三、Spring与Quartz集成步骤详解 1. **引入必要的JAR包**: - `spring.jar`:包含Spring核心库。 - `...

    Spring集成Quartz定时任务框架介绍.docx

    ### Spring集成Quartz定时任务框架介绍 #### 一、引言 在现代JavaEE应用程序开发过程中,定时任务是一项常见的需求。这些任务可能包括但不限于:每天固定时间生成报表、定期清理缓存、定时发送邮件提醒等。传统的...

    quartz集群调度

    - **LOCKS表**:Quartz使用LOCKS表来控制对关键资源的访问,避免并发冲突。在读取或更新关键信息时,会先尝试获取锁。 - **JobStore**:作为中间层,JobStore负责执行数据库操作,包括读取JobDetail、Trigger等信息...

    ssh注解零配置增删改查,Spring+hibernate+Struts2

    在这个案例中,项目可以直接在MyEclipse中运行,表明所有必要的库和依赖都已经包含在内,且没有版本冲突问题。 **数据库连接**:由于数据库表是在代码中定义的,可能使用了Spring的JDBC模板或者Hibernate的...

    springboot的schedule和quartz到底怎么选以及如何支持并发和避坑

    在开发Java Web应用程序时,定时任务的实现是一个常见的需求,Spring Boot为我们提供了两种主要的解决方案:Spring Boot的`@Scheduled`注解和Quartz Scheduler。本文将深入探讨这两种选择的适用场景、优缺点,以及...

Global site tag (gtag.js) - Google Analytics