11

我们正在使用 JPA2.0 和 Hibernate3.0 实现一个 Web App。连接池配置在 META-INF 文件夹中的 persistence.xml 中设置。


持久性.xml:

<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0">
    <persistence-unit name="MyPU" transaction-type="RESOURCE_LOCAL">
        <!-- Entity Classes-->
        <properties>
            <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect"/>
            <property name="hibernate.show_sql" value="true"/>
            <property name="bytecode.provider"   value="org.hibernate.bytecode.javassist.BytecodeProviderImpl"/>
            <property name="hibernate.connection.username" value="{username}"/>
            <property name="hibernate.connection.password" value="{password}"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
            <property name="hibernate.format_sql" value="true"/>
            <property name="hibernate.connection.url" value="{jdbc url}"/>

            <property name="hibernate.c3p0.min_size" value="1"/>
            <property name="hibernate.c3p0.timeout" value="1000"/>
            <property name="hibernate.c3p0.acquire_increment" value="1"/>
            <property name="hibernate.c3p0.idle_test_periods" value="600"/>
            <property name="hibernate.c3p0.testConnectionOnCheckin" value="true"/>
            <property name="hibernate.c3p0.preferredTestQuery" value="SELECT 1;"/>
       </properties>
    </persistence-unit>
</persistence>

我们的连接池配置有问题。配置好像没有效果,8小时后连接断开。我们是否需要另一个配置文件,如 hibernate.cfg.xml 或 hibernate.properties?

4

4 回答 4

4

I had this same problem with the proprieties that I put in persistence.xml didn't affect c3p0.

Looking into http://www.mchange.com/projects/c3p0/index.html#configuration_files I tried to put an xml file named c3p0-config.xml and put it in WEB-INF/classes and it work perfectly.

Here is an example of a c3p0-config.xml file:

<c3p0-config>
  <default-config>
    <property name="automaticTestTable">con_test</property>
    <property name="checkoutTimeout">30000</property>
    <property name="idleConnectionTestPeriod">30</property>
    <property name="initialPoolSize">10</property>
    <property name="maxIdleTime">30</property>
    <property name="maxPoolSize">100</property>
    <property name="minPoolSize">10</property>
    <property name="maxStatements">200</property>

    <user-overrides user="test-user">
      <property name="maxPoolSize">10</property>
      <property name="minPoolSize">1</property>
      <property name="maxStatements">0</property>
    </user-overrides>

  </default-config>
</c3p0-config>
于 2013-02-27T11:44:31.673 回答
3

好问题,坏标题。:) 我想我在你的转贴中回答了这个问题:c3p0 的最佳配置

于 2012-09-21T13:23:45.290 回答
1

我有同样的问题,我的问题是我的 Web 应用程序容器(Tomcat)正在管理我的数据库连接。我不得不将 c3p0 配置从我的 persistence.xml 文件移动到 Tomcat 的 context.xml。如果这是您的问题,Domenic D 提供的链接是一个很好的起点。

于 2014-09-09T14:40:35.597 回答
1

你的设置有错别字,应该idle_test_period不是idle_test_periods

有关设置的信息,请参阅此帖子:c3p0.idle_test_period 的使用。

于 2018-03-14T11:12:51.467 回答