配置 Hibernate 以使用 C3P0 连接池

通过本教程,我想与您分享如何配置您的 Java 项目以及它的休眠配置文件 hibernate.cfg.xml 以使用更专业和生产就绪的连接池提供程序C3P0

Hibernate 的内部连接池算法是初级的,是为开发和测试目的而提供的。

在我之前的博客文章中,我使用了默认的休眠连接池,但在生产环境中使用它不如C3P0好好消息是,更新使用 Hibernate 的默认连接轮询以使用更好的连接轮询的 Java 项目并不需要花费太多精力。

要更新使用默认连接池的 Java 项目以使用 C3P0 ,我们需要执行 2 个步骤:

  • 通过添加hibernate-c3p0的依赖来更新 pom.xml
  • 更新我们项目中的 Hibernate 配置文件hibernate.cfg.xml  以使用新的C3P0 连接池。

添加 C3P0 Maven 依赖

 

将 c3p0 连接池依赖添加到我们的项目中。打开您的 pom.xml 文件并在依赖项列表中再添加一项。 

<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-c3p0 -->
<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-c3p0</artifactId>
    <version>5.2.12.Final</version>
</dependency>

或者您可以下载 JAR 文件并将其手动添加到您的库列表中。以下是下载 JAR 文件的链接:

https://mvnrepository.com/artifact/org.hibernate/hibernate-c3p0/5.2.12.Final

更新 hibernate.cfg.xml 以使用 C3P0 连接池

如果设置 hibernate.c3p0.* 属性,Hibernate 使用 C3P0ConnectionProvider 进行连接池。

如果您使用默认休眠的默认连接池,则从您的 hibernate.cfg.xml 文件中删除以下行:

<property name="connection.pool_size">10</property>

代替上面的行,添加以下 4:

 <property name="hibernate.c3p0.min_size">3</property>
 <property name="hibernate.c3p0.max_size">20</property>
 <property name="hibernate.c3p0.timeout">300</property>
 <property name="hibernate.c3p0.max_statements">50</property>

在哪里: 

  • hibernate.c3p0.min_size – 池中的最小 JDBC 连接数
  • hibernate.c3p0.max_size – 池中的最大 JDBC 连接数
  • hibernate.c3p0.timeout - 指定何时从池中删除空闲连接(以秒为单位),
  • hibernate.c3p0.max_statements – 将被缓存的准备好的语句的数量。缓存很好,因为它提高了应用程序的性能。但如果您决定关闭缓存,则将此值设置为0。

这是我更新的 hibernate.cfg.xml 文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/photo_app</property>
        <property name="hibernate.connection.username">Sergey</property>
        <property name="hibernate.connection.password">sergey</property>
        
        <property name="hibernate.id.new_generator_mappings">true</property>  
        <property name="show_sql">true</property> 
        <property name="hibernate.hbm2ddl.auto">update</property>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
       
        <property name="hibernate.c3p0.min_size">5</property>
        <property name="hibernate.c3p0.max_size">20</property>
        <property name="hibernate.c3p0.timeout">300</property>
        <property name="hibernate.c3p0.max_statements">50</property>
        <property name="hibernate.c3p0.idle_test_period">3000</property>
 
        <mapping class="com.appsdeveloperblog.ws.io.entity.UserProfileEntity"/>
 
    </session-factory>
</hibernate-configuration>

我希望这个简短的教程对你有所帮助。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值