【问题标题】:Do I have to close() every EntityManager?我必须关闭()每个 EntityManager 吗?
【发布时间】:2010-09-18 05:38:35
【问题描述】:

我刚刚开始将我自己开发的持久性框架迁移到 JPA。

鉴于持久性框架隐藏了很多管道,我很想知道不关闭 EntityManagers 是否会造成资源泄漏,或者框架是否会为我收集并关闭它们。

我打算在所有地方关闭它们,但我必须这样做吗?

目前使用 TopLink,只是因为它很容易与 NetBeans 配合使用,但很高兴研究其他 JPA 提供程序。

【问题讨论】:

标签: java jpa persistence toplink


【解决方案1】:

我在我的存储库中使用@PersistenceContext 注释获得了EntityManager。我可以看到,在连接池到达其maxPoolSize 后,它并没有被清理。

但是,如果我使用EntityManagerFactory 创建EntityManager 并调用entitymanager.close(),那么连接就会被清理。我使用c3p0 作为连接池库。

【讨论】:

    【解决方案2】:

    这取决于你如何获得它。

    如果您使用 EntityManagerFactory 创建它,则无论您使用什么框架,都必须关闭它。

    如果您使用依赖注入(例如使用 EJB 和 @PersistenceContext 注释)获得它,则不应手动关闭它(AFAIK 它将导致 RuntimeException)。

    【讨论】:

    • 在更广泛的意义上,EM 仍然应该关闭。这只是 EJB 为您完成的工作,您通过遵守 EJB 要求使其成为可能。
    【解决方案3】:

    你应该。

    Frameworks 不知道您打算如何使用 EM,因此它们无法关闭它(除非可能是在最终确定时,但不能保证)。是的,不关闭它们会造成资源泄漏。

    这个想法与“总是关闭 java.sql.Connection”(尽管某些数据源具有通过不活动自动关闭它们的设置)或“总是关闭 Hibernate 会话”相同。

    此外,如果您打算编写可移植代码,则不应依赖特定的 JPA 提供者“聪明”——其他可能无法及时关闭 EM。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-07-02
      • 1970-01-01
      • 2015-06-30
      • 2013-04-29
      • 2012-02-13
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多