Java 如果配置了Tomcat JDBC数据源,是否需要Hibernate c3p0配置

Java 如果配置了Tomcat JDBC数据源,是否需要Hibernate c3p0配置,java,spring,datasource,Java,Spring,Datasource,也许我没有正确理解这里的某些内容。如果您已经像下面这样配置了数据源 <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:

也许我没有正确理解这里的某些内容。如果您已经像下面这样配置了数据源

<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>

${jdbc.schema}
${hibernate.generate_statistics}
org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory
真的
真的
真的
ehcache.xml
真的
5.
20
600
50
真的
如果没有,哪一个更好


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

在这种情况下,Spring给您带来的好处是,您可以提供自己的
数据源
,并使用您想要/需要的连接池实现,而不管您的应用程序将部署在何处,因此您的应用程序将完全独立于应用程序服务器(在本例中,Tomcat充当servlet容器)


从这一点上讲,这取决于您决定使用哪个连接池实现。我建议使用HikariCP而不是C3P0或Tomcat。免责声明:我不以任何方式支持HikariCP,我只是一个快乐的技术用户。

如果您希望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>

c3p0
.

关于C3P0池和spring,请参见和。

此数据源在spring-jpa-configuration.xml中配置,Tomcat不用于应用程序。我只是在可以使用Hikari的地方使用了TomcatJDBC。但问题还是一样的。我在LocalContainerEntityManagerFactoryBean中放置的内容正在影响池的发生方式?我甚至没有以这种方式配置
EntityManagerFactory
。我只是使用
并定义
数据源
。这样,我只需要处理一个bean配置,也许我应该给出完整的配置。正如你在我的编辑中看到的,我也做了同样的事情。然而,我在那里写的东西,在我的脑海中,我设置了两次游泳池。一次在数据源配置中,一次在LocalEntityManagerFactory中。如果已经使用了
,则不需要传递任何其他数据库连接参数。所有这些参数都应该在
数据源
中设置,而不是在其他地方。
<Resource name="jdbc/sample" auth="Container"
    type="com.mchange.v2.c3p0.ComboPooledDataSource"
    username=...
    password=...
    url=...
    driverClassName=...
    otherAttributes...
/>