0

我正在使用 Struts 2.2.1.1 和 Hibernate 3.6.2.Final。我还将 C3P0 用于在 Tomcat 7.0.11 上运行的连接池。

我遇到的问题是我的 Hibernate 会话没有被关闭,并且我很快超过了“hibernate.c3p0.max_size”属性中配置的最大打开连接数。

我认为这是因为我的休眠会话已打开但从未关闭。我正在从存储在 ServletContext 中的 SessionFactory 打开 Sessions。我尝试在我的 Action 类的 finally{} 块中关闭会话,但这会引发 org.hibernate.LazyInitializationException 异常。

我做了一些研究,发现了Full Hibernate Plugin方法和Open Session in View方法。

我假设这是一个常见问题,我想了解一下最常用的解决方案。

我注意到的另一件事是 Full Hibernate Plugin 支持 Struts 2.0.9+ 到 2.1.6,但我使用的是 2.2.1.1。不确定这是否会成为问题,或者网站是否尚未更新以列出较新版本。

非常感谢任何输入。

4

1 回答 1

1

我从未使用过休眠插件,但我鼓励您采用Open Session in View模式。你肯定想关闭你的会话。

处理此问题的最常见方法之一是在请求开始时创建会话,将其存储在本地线程中,然后在请求结束时关闭它。这可以通过 Struts 拦截器或 servlet 过滤器来完成。基本上:

public class HibernateSessionInterceptor extends AbstractInterceptor {
    @Override
    public String intercept(final ActionInvocation invocation) throws Exception {
        try {
            // create the session and place it in the ThreadLocal
            return invocation.invoke();
        } finally {
            // close the session and remove it from the ThreadLocal
        }
    }
}

如果您使用 Google Guice,则有一个基于 JPA 的持久性插件(guice-persist)。它使用相同的方法,但使用了 servlet 过滤器。

于 2011-05-05T20:12:39.703 回答