这是一个在 WAS8.0 上运行的 JSF 2 应用程序。这是一页的“支持”bean的代码。
@Named("mySessionBean")
@SessionScoped
@Stateful
@LocalBean
@StatefulTimeout(unit = TimeUnit.MINUTES, value = 10)
public class MySessionBean implements Serializable {
@PostConstruct
public void init()
{
System.out.println("start MySessionBean: " + this.hashCode());
}
@PreDestroy
public void cleanup()
{
System.out.println("destroy MySessionBean: " + this.hashCode());
}
....
}
web.xml 中设置的会话超时值小于 bean 的超时值。当我运行应用程序时,我看到了来自@PostConstruct 的打印输出,但从未看到来自@PreDestroy 的打印输出。我尝试了以下 2 种情况: 1. 注销 - invalidateSession;2. 只需等到会话到期。
我不是应用程序的设计者。设计者坚持把所有的backing bean作为一个有状态的session bean。我认为更主流的方法就是让它们成为 CDI bean。但无论如何,当我只将注释更改为 CDI 时,我也开始从 @PreDestroy 获取打印输出
@Named("mySessionBean")
@SessionScoped
public class MySessionBean implements Serializable {
.....
我的问题是,在第一种情况下我没有得到 @PreDestroy 方法调用的原因是什么?如果我看不到 @PreDestroy 被调用,是否有任何其他方法可以跟踪“支持”bean(在本例中为有状态会话 bean)的生命周期。谢谢!