使用IntrospectorCleanupListener 解决quartz引发的内存泄漏

"在服务器运行过程当中,Spring不停的运行的计划任务和OpenSessionInViewFilter,使得Tomcat反复加载对象而产生框架并用时可能产生的内存泄漏,则使用IntrospectorCleanupListener做为相应的解决办法。"java

对于这一句话,引用关于IntrospectorCleanupListener一段解释:web

引用spring

spring中的提供了一个名为 org.springframework.web.util.IntrospectorCleanupListener的监听器。它主要负责处理由  JavaBeans  Introspector的使用而引发的缓冲泄露。spring中对它的描述以下:它是一个在web应用关闭的时候,清除JavaBeans  Introspector的监听器.web.xml中注册这个listener.能够保证在web 应用关闭的时候释放与掉这个web  应用相关的class loader 和由它管理的类若是你使用了JavaBeans  Introspector来分析应用中的类,Introspector 缓冲中会保留这些类的引用.结果在你的应用关闭的时候,这些类以及web  应用相关的class  loader没有被垃圾回收.不幸的是,清除Introspector的惟一方式是刷新整个缓冲.这是由于咱们无法判断哪些是属于你的应用的引用.因此删 除被缓冲的introspection会致使把这台电脑上的全部应用的introspection都删掉.须要注意的是,spring  托管的bean不须要使用这个监听器.由于spring它本身的introspection所使用的缓冲在分析完一个类以后会被立刻从javaBeans Introspector缓冲中清除掉.应用程序中的类历来不直接使用JavaBeans  Introspector.因此他们通常不会致使内部查看资源泄露.可是一些类库和框架每每会产生这个问题.例如:Struts  和Quartz.单个的内部查看泄漏会致使整个的web应用的类加载器不能进行垃圾回收.在web应用关闭以后,你会看到此应用的全部静态类资源(例如单 例).这个错误固然不是由这个类自 身引发的.服务器

用法很简单,就是在web.xml中加入:
< listener>
< listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
< /listener>框架

只知道servlet标准不容许在web容器内自行作线程管理,quartz的问题确实存在。  异步

对于Web容器来讲,最忌讳应用程序私自启动线程,自行进行线程调度,像Quartz这种在web容器内部默认就本身启动了10线程进行异步job调度的框架自己就是很危险的事情,很容易形成servlet线程资源回收不掉,因此我一贯排斥使用quartz。 线程

quartz还有一个问题就是不支持cluster。致使使用quartz的应用都没有办法作群集。 xml

若是是个人话,我采起的办法就是本身单独启动一个Job Server,来跑job,不会部署在web容器中。 对象

相关文章
相关标签/搜索