在tomcat关闭时没有在会话范围的Spring bean上调用@PreDestroy

使用Spring 3.0.5 GA

使用@PreDestroy方法创建一个Session-scoped bean.注意到如果拥有HttpSession超时(即超过Servlet容器的会话超时值),则会发出@PreDestroy回调.但是,如果我只是关闭app服务器,则不会调用@PreDestroy.这是设计还是错误?如果是后者,对于解决方案的任何建议?

在两种情况下都会调用单个bean上的FWIW,@ PreDestroy.

谢谢,
-nikita

PS.有一个可能相关的Spring bug – SPR-7359

最佳答案
有趣.当会话关闭事件发生时,会话范围的bean会调用它们的@Predestroy.如果容器从不发送该事件,则不会通知Spring.我不确定这是否构成了一个bug,如果是这样,那么它就是Spring或Tomcat中的一个bug.后者似乎更有可能,但我不知道Servlet容器是否有义务这样做.

如果这是一个show-stopper对你来说,你可能想要考虑让scoped bean在@postconstruct注册一个“registrar”单例,并在@PreDestroy上注销自己.如果注册器已关闭,它可以将该事件传播到仍在其中注册的任何剩余的会话范围的bean.

不理想,但是务实的解决方案.

相关文章

这篇文章主要介绍了spring的事务传播属性REQUIRED_NESTED的原...
今天小编给大家分享的是一文解析spring中事务的传播机制,相...
这篇文章主要介绍了SpringCloudAlibaba和SpringCloud有什么区...
本篇文章和大家了解一下SpringCloud整合XXL-Job的几个步骤。...
本篇文章和大家了解一下Spring延迟初始化会遇到什么问题。有...
这篇文章主要介绍了怎么使用Spring提供的不同缓存注解实现缓...