【问题标题】:Is Hibernate c3p0 configuration needed if Tomcat JDBC datasource is configured如果配置了 Tomcat JDBC 数据源,是否需要 Hibernate c3p0 配置
【发布时间】:2015-05-27 12:47:03
【问题描述】:

也许我在这里没有正确理解某些内容。如果有人像下面这样配置数据源

<bean id="dataSource" class="org.apache.tomcat.jdbc.pool.DataSource" destroy-method="close" p:driverClassName="${jdbc.driverClassName}"
p:url="${db.url}" p:username="${db.username}" p:password="${db.password}" 
p:initialSize="10" 
p:minIdle="10" 
p:maxIdle="20" 
p:maxActive="50"
p:timeBetweenEvictionRunsMillis="30000"     
p:minEvictableIdleTimeMillis="60000"
p:validationQuery="SELECT 1"
p:validationInterval="30000" />

将以下属性添加到

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">

<property name="dataSource" ref="dataSource" />

<property name="jpaProperties">
  <props>

    <prop key="hibernate.default_schema">${jdbc.schema}</prop>
    <prop key="hibernate.generate_statistics">${hibernate.generate_statistics}</prop>

    <prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory</prop>
    <prop key="hibernate.cache.use_query_cache">true</prop>
    <prop key="hibernate.cache.use_second_level_cache">true</prop>
    <prop key="hibernate.generate_statistics">true</prop>
    <prop key="hibernate.cache.provider_configuration_file_resource_path">ehcache.xml</prop>
    <prop key="hibernate.cache.region_prefix"></prop>
    <prop key="hibernate.cache.use_structured_entries">true</prop>

    <prop key="hibernate.c3p0.minPoolSize">5</prop>
    <prop key="hibernate.c3p0.maxPoolSize">20</prop> 
    <prop key="hibernate.c3p0.timeout">600</prop> 
    <prop key="hibernate.c3p0.max_statement">50</prop>
    <prop key="hibernate.c3p0.testConnectionOnCheckout">true</prop>

    </props>
</property>

如果没有。哪个更好?

在我看来,我上面配置的是两次池。一次使用 Tomcat JDBC,另一次使用 c3p0。

【问题讨论】:

    标签: java spring datasource


    【解决方案1】:

    在这种情况下,Spring 为您提供的好处是,您可以提供自己的 DataSource 并使用您想要/需要的连接池实现,而不管您的应用程序将部署在哪里,因此您的应用程序将完全独立于应用程序服务器(在本例中,Tomcat 用作 servlet 容器)。

    从现在开始,取决于您决定使用哪个连接池实现。 IMO 我建议使用 HikariCP 而不是 C3P0 或 Tomcat。免责声明:我绝不支持 HikariCP,我只是该技术的快乐用户。

    【讨论】:

    • 此数据源在 spring-jpa-configuration.xml 中配置,应用程序不使用 Tomcat。我只是在可以使用 Hikari 的地方使用了 tomcat jdbc。问题将保持不变。我放入 LocalContainerEntityManagerFactoryBean 的内容会影响池的发生方式?
    • 我什至没有以这种方式配置EntityManagerFactory。我只是使用&lt;property name="dataSource" ref="myDataSource" /&gt; 并使用我想要/需要的连接池框架中的DataSource 定义&lt;bean id="myDataSource" class="..."&gt; ... &lt;/bean&gt;。这样,我只需要搞乱一个单一的bean配置。
    • 可能我应该给出完整的配置。正如你在我的编辑中看到的那样,我也做同样的事情。但是,我在那里写的内容,在我的脑海中我设置了两次池。一次进入数据源配置,一次进入 LocalEntityManagerFactory。
    • 如果您已经使用&lt;property name="dataSource" ... /&gt;,那么您不需要传递任何其他数据库连接参数。所有这些参数都应该在DataSource 中设置,别无他处。
    【解决方案2】:

    如果你想让 spring 从 c3p0 池中获取数据源,只需让 LocalContainerEntityManagerFactoryBean 引用 c3p0 数据源 bean。这里是一个例子。

    <bean id="entityManagerFactory"
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource" />
        ...
    </bean>
    <bean id="dataSource" class = "com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
        <property name="driverClass" value="${jdbc.driverClassName}" />
        <property name="jdbcUrl" value="${jdbc.url}" />
        <property name="user" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" /> 
    
        <!-- these are C3P0 properties -->
        <property name="acquireIncrement" value="${c3p0.acquireIncrement}" />
        <property name="minPoolSize" value="${c3p0.minPoolSize}" />
        <property name="maxPoolSize" value="${c3p0.maxPoolSize}" />
        <property name="maxIdleTime" value="${c3p0.maxIdleTime}" />
    </bean>
    

    您可以根据需要配置属性。 您需要将 c3p0 依赖添加到您的项目中:

    <dependency>
      <groupId>c3p0</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.1.2</version><!--Maybe this is not the newest version-->
      <type>jar</type>
      <scope>compile</scope>
    </dependency>
    

    我想知道为什么不使用JNDI来提供数据源?以Tomcat为例,在$TOMCAT_HOME/Context.xml、Server.xml中:

    <Resource name="jdbc/sample" auth="Container"
        type="com.mchange.v2.c3p0.ComboPooledDataSource"
        username=...
        password=...
        url=...
        driverClassName=...
        otherAttributes...
    /> 
    

    要引用 JNDI 数据源,请参阅 here。 关于 C3P0 池化和 spring 参见 herehere

    【讨论】:

      猜你喜欢
      • 2011-02-27
      • 2014-07-07
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-01-09
      • 2013-04-09
      • 2017-08-22
      • 2018-06-26
      相关资源
      最近更新 更多