3

这应该是一个老问题,但我搜索了很多,没有发现任何有用的东西。我的主要问题是,当连接丢失时,我的 Java swing 应用程序会冻结。必须有一个连接超时,以便应用程序通知用户。

我试过这个这个,但它们没有帮助。

这真的是 EclipseLink 的一个弱点,还是我想不通?

编辑:这是我通过 EclipseLink 连接的方式:

private static javax.persistence.EntityManager em = null;
public static javax.persistence.EntityManager getEntityManager()
{
    if (em == null || !em.isOpen())
    {
        try
        {
            em = Persistence
                  .createEntityManagerFactory("persistenceUnitName", getPersistenceConfig()).createEntityManager();
        } catch (Exception e)
        {
           //log
        }
    }
    return em;
}

这是我的persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xsi:schemaLocation="http://java.sun.com/xml/ns/persistence  http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="persistenceUnitName" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<class>org.entities.MyEntity</class>
<shared-cache-mode>NONE</shared-cache-mode>
<validation-mode>NONE</validation-mode>
<properties>
  <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
</properties>

Swing 和em在同一个线程中,em无法检索数据,所以 Swing 正在等待em并冻结。

4

1 回答 1

0

您的应用程序挂在哪里?请中断或调试进程并获取堆栈转储。

如果它挂在查询上,您可以设置查询超时,这可能会有所帮助。

它很可能挂在 JDBC 驱动程序上,JPA 无能为力。检查您的 JDBC 驱动程序中是否有任何设置以防止挂起。

于 2012-07-31T14:11:39.350 回答