SQL 已关闭连接 - 需要增加超时时间?
SQL closed Connection - need to increase timeout?
当连接到我的 Oracle
数据库时,我在 Java
应用程序中得到 'SQL Closed connection'。
我是否需要增加超时时间或对我的 XML 配置进行任何其他更改?
下面是我的persistence
.xml文件:
<persistence-unit name="mypersistenceUnit">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.my.package.entities.Person</class>
<class>com.my.package.entities.Address</class>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect"/>
<property name="hibernate.connection.provider_class" value="org.hibernate.c3p0.internal.C3P0ConnectionProvider"/>
<property name="hibernate.c3p0.max_size" value="1"/>
<property name="hibernate.c3p0.min_size" value="1"/>
<property name="hibernate.c3p0.acquire_increment" value="2"/>
<property name="hibernate.c3p0.idle_test_period" value="300"/>
<property name="hibernate.c3p0.max_statements" value="15"/>
<property name="hibernate.c3p0.timeout" value="0"/>
<property name="hibernate.c3p0.unreturnedConnectionTimeout" value="30000"/>
<property name="hibernate.c3p0.dataSourceName" value="mypersistenceUnit JPA"/>
<property name="hibernate.jdbc.fetch_size" value="50"/>
<property name="hibernate.default_batch_fetch_size" value="10"/>
</properties>
</persistence-unit>
也许 Oracle 提供给您的连接最终超时或过期(尽管您配置了空闲连接测试)。在任何情况下,您的连接测试可能会更严格,每五分钟一次空闲测试之间中断的连接将被移交给中断的客户端,可能会引发您的异常。
我会添加
<property name="hibernate.c3p0.testConnectionOnCheckout" value="true"/>
看看这是否能解决问题。另见 c3p0's docs。
当连接到我的 Oracle
数据库时,我在 Java
应用程序中得到 'SQL Closed connection'。
我是否需要增加超时时间或对我的 XML 配置进行任何其他更改?
下面是我的persistence
.xml文件:
<persistence-unit name="mypersistenceUnit">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.my.package.entities.Person</class>
<class>com.my.package.entities.Address</class>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect"/>
<property name="hibernate.connection.provider_class" value="org.hibernate.c3p0.internal.C3P0ConnectionProvider"/>
<property name="hibernate.c3p0.max_size" value="1"/>
<property name="hibernate.c3p0.min_size" value="1"/>
<property name="hibernate.c3p0.acquire_increment" value="2"/>
<property name="hibernate.c3p0.idle_test_period" value="300"/>
<property name="hibernate.c3p0.max_statements" value="15"/>
<property name="hibernate.c3p0.timeout" value="0"/>
<property name="hibernate.c3p0.unreturnedConnectionTimeout" value="30000"/>
<property name="hibernate.c3p0.dataSourceName" value="mypersistenceUnit JPA"/>
<property name="hibernate.jdbc.fetch_size" value="50"/>
<property name="hibernate.default_batch_fetch_size" value="10"/>
</properties>
</persistence-unit>
也许 Oracle 提供给您的连接最终超时或过期(尽管您配置了空闲连接测试)。在任何情况下,您的连接测试可能会更严格,每五分钟一次空闲测试之间中断的连接将被移交给中断的客户端,可能会引发您的异常。
我会添加
<property name="hibernate.c3p0.testConnectionOnCheckout" value="true"/>
看看这是否能解决问题。另见 c3p0's docs。