`

ch05 hibernate的连接池讲义

 
阅读更多
本章任务

1:hibernate的连接池

(1): C3P0 

只需在hibernate.cfg.xml中加入 
<property name="c3p0.min_size">5</property> 
<property name="c3p0.max_size">30</property> 
<property name="c3p0.time_out">1800</property> 
<property name="c3p0.max_statement">50</property> 

还有在classespath中加入c3p0-0.8.4.5.jar 


(2): dbcp 

在hibernate.cfg.xml中加入 

<property name="dbcp.maxActive">100</property> 
<property name="dbcp.whenExhaustedAction">1</property> 
<property name="dbcp.maxWait">60000</property> 
<property name="dbcp.maxIdle">10</property> 

<property name="dbcp.ps.maxActive">100</property> 
<property name="dbcp.ps.whenExhaustedAction">1</property> 
<property name="dbcp.ps.maxWait">60000</property> 
<property name="dbcp.ps.maxIdle">10</property> 


还有在classespath中加入commons-pool-1.2.jar 和commons-dbcp-1.2.1.jar. 


(3): proxool 

步骤1:在hibernate.cfg.xml中加入 

<property name="proxool.pool_alias">pool1</property> 
<property name="proxool.xml">ProxoolConf.xml</property> 
<property name="connection.provider_class">org.hibernate.connection.ProxoolConnectionProvider</property> 

步骤2:在和hibernate.cfg.xml同一个目录下,加一个ProxoolConf.xml文件,内容为 

<?xml version="1.0" encoding="utf-8"?> 
<!-- the proxool configuration can be embedded within your own application's. 
Anything outside the "proxool" tag is ignored. --> 
<something-else-entirely> 
<proxool> 
<alias>pool1</alias> 
<!--proxool只能管理由自己产生的连接--> 
<driver-url>jdbc:mysql://localhost:3306/struts?useUnicode=true&characterEncoding=GBK</driver-url> 
<driver-class>org.gjt.mm.mysql.Driver</driver-class> 
<driver-properties> 
<property name="user" value="root"/> 
<property name="password" value="8888"/> 
</driver-properties> 
<!-- proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁--> 
<house-keeping-sleep-time>90000</house-keeping-sleep-time> 
<!-- 指因未有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的用户连接就不会被接受--> 
<maximum-new-connections>20</maximum-new-connections> 
<!-- 最少保持的空闲连接数--> 
<prototype-count>5</prototype-count> 
<!-- 允许最大连接数,超过了这个连接,再有请求时,就排在队列中等候,最大的等待请求数由maximum-new-connections决定--> 
<maximum-connection-count>100</maximum-connection-count> 
<!-- 最小连接数--> 
<minimum-connection-count>10</minimum-connection-count> 
</proxool> 
</something-else-entirely> 


步骤3:并在classespath中加入proxool-0.8.3.jar 

结论: 

由于在hibernate3.0中,已经不再支持dbcp了,hibernate的作者在hibernate.org中,明确指出在实践中发现dbcp有 BUG,在某些种情会产生很多空连接不能释放,所以抛弃了对dbcp的支持。

至于c3p0,有评论说它的算法不是最优的,c3p0占用资源比较大,效率也不高。 

备注:
--Proxool常用属性

解决办法:

import org.logicalcobwebs.proxool.ProxoolFacade;

因为我写的是application 
所以在结束后要自己关掉connection pool 

所以在finally 要加上 ProxoolFacade.shutdown(0); 
0 为立即..里面为延迟几分钟后关掉 

finally{ 
       try{         
         stmt.close(); 
                 con.close();          
         //停掉connection pool 
         ProxoolFacade.shutdown(0); 
       }catch(Exception e){ 
         logger.severe("connection close faile!!"); 
               } 
     
     }


Proxool常用属性:




下面是全部的属性列表:

fatal-sql-exception: 它是一个逗号分割的信息片段.当一个SQL异常发生时,他的异常信息将与这个信息片段进行比较.如果在片段中存在,那么这个异常将被认为是个致命错误(Fatal SQL Exception ).这种情况下,数据库连接将要被放弃.无论发生什么,这个异常将会被重掷以提供给消费者.用户最好自己配置一个不同的异常来抛出.

fatal-sql-exception-wrapper-class:正如上面所说,你最好配置一个不同的异常来重掷.利用这个属性,用户可以包装SQLException,使他变成另外一个异常.这个异常或者继承SQLException或者继承字RuntimeException.proxool自带了2个实现:'org.logicalcobwebs.proxool.FatalSQLException' 和'org.logicalcobwebs.proxool.FatalRuntimeException' .后者更合适.

house-keeping-sleep-time: house keeper 保留线程处于睡眠状态的最长时间,house keeper 的职责就是检查各个连接的状态,并判断是否需要销毁或者创建.

house-keeping-test-sql: 如果发现了空闲的数据库连接.house keeper 将会用这个语句来测试.这个语句最好非常快的被执行.如果没有定义,测试过程将会被忽略。

injectable-connection-interface: 允许proxool实现被代理的connection对象的方法.

injectable-statement-interface: 允许proxool实现被代理的Statement 对象方法.

injectable-prepared-statement-interface: 允许proxool实现被代理的PreparedStatement 对象方法.

injectable-callable-statement-interface: 允许proxool实现被代理的CallableStatement 对象方法.

jmx: 略

jmx-agent-id: 略

jndi-name: 数据源的名称

maximum-active-time: 如果housekeeper 检测到某个线程的活动时间大于这个数值.它将会杀掉这个线程.所以确认一下你的服务器的带宽.然后定一个合适的值.默认是5分钟.

maximum-connection-count: 最大的数据库连接数.

maximum-connection-lifetime: 一个线程的最大寿命.

minimum-connection-count: 最小的数据库连接数

overload-without-refusal-lifetime: 略

prototype-count: 连接池中可用的连接数量.如果当前的连接池中的连接少于这个数值.新的连接将被建立(假设没有超过最大可用数).例如.我们有3个活动连接2个可用连接,而我们的prototype-count是4,那么数据库连接池将试图建立另外2个连接.这和 minimum-connection-count不同. minimum-connection-count把活动的连接也计算在内.prototype-count 是spare connections 的数量.

recently-started-threshold: 略

simultaneous-build-throttle: 略

statistics: 略

statistics-log-level: 略

test-before-use: 略

test-after-use: 略

trace: 如果为true,那么每个被执行的SQL语句将会在执行期被log记录(DEBUG LEVEL).你也可以注册一个ConnectionListener (参看ProxoolFacade)得到这些信息.

1
1
分享到:
评论

相关推荐

    CH08Hibernate框架介绍.ppt

    CH08Hibernate框架介绍.ppt

    Oracle+数据库例子(数据库连接池+中文乱码+留言板+过滤器)

    在ch8数据库连接池这个章节中,你可以找到如何配置和使用数据库连接池的示例代码,这对于优化Web应用程序的性能至关重要。 其次,"解决中文乱码"是Web开发中常遇到的问题。由于字符编码不一致,可能导致中文显示为...

    android ophone开发完全讲义源码ch05

    《Android OPhone开发完全讲义源码Ch05》是一份深入探讨Android OPhone平台开发的教程资料,其中包含了第五章的源代码。这个压缩包是开发者和学习者宝贵的资源,帮助他们理解并实践Android OPhone应用的开发过程。...

    ch战略领袖SouthWesternCollege战略讲义实用PPT学习教案.pptx

    ch战略领袖SouthWesternCollege战略讲义实用PPT学习教案.pptx

    精通hibernate源码ch2

    - hibernate.cfg.xml:这是Hibernate的主配置文件,定义了数据库连接信息、JDBC驱动等。 - Mapping文件(.hbm.xml):对象-关系映射文件,描述了Java类与数据库表的对应关系。 3. 实体类(Entity)与持久化: - ...

    精通hibernate源码ch3

    1. Hibernate配置:包括XML配置文件(hibernate.cfg.xml)的设置,数据库连接参数,以及实体类和数据库表的映射配置。 2. Session工厂与Session:解释如何创建SessionFactory对象,它是Session的工厂,而Session是...

    精通hibernate源码ch5

    《精通Hibernate源码Chapter5:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅能帮助开发者提高工作效率,还能...

    数据库ch05数据库ch05.ppt

    数据库ch05数据库ch05

    精通J2EE--ECLIPSE、STRUTS、HIBERNATE及SPRING整合应用案例代码-ch05

    在本案例的ch05目录中,可能包含了配置文件(如hibernate.cfg.xml)、实体类、映射文件(.hbm.xml)以及与数据库交互的DAO。 **Spring** 是一个全面的后端应用程序框架,涵盖了依赖注入(DI)、AOP(面向切面编程)...

    hibernate_reference.pdf

    - **配置文件**:通常使用 `hibernate.cfg.xml` 文件来配置 Hibernate 的各种属性,如数据库连接信息、方言(Dialect)、缓存配置等。 - **映射文件**:每个实体类都需要有一个对应的映射文件(`.hbm.xml`),用于...

    CH4Hibernate2,一对多,多对一,多对多实现增删改查

    在`CH4Hibernate2`项目中,你可以通过解压文件并导入到MyEclipse或Eclipse中,然后配置合适的数据库连接和依赖(如Hibernate库),修改相关路径,就可以运行示例代码,体验这些关系在实际操作中的运用。通过增删改查...

    精通hibernate源码ch4

    《精通Hibernate源码Chapter4:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅可以帮助开发者提高开发效率,还...

    测试Hibernate数据库ch03.sql

    测试Hibernate数据库ch03.sql

    hibernate2ch_reference.pdf

    Hibernate的配置涉及多个方面,包括数据库连接信息、实体类路径、缓存设置等。配置文件通常为hibernate.cfg.xml,其中需明确指定JDBC驱动、URL、用户名和密码。此外,还可以通过编程方式进行动态配置。 3. **...

    精通hibernate源码ch1

    《精通Hibernate源码Chapter1:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅可以帮助开发者更好地利用其功能...

    win7_driver.zip_CH341_CH341SER.INF wi_CH341SER.INF win7_ch341 l

    "使用这个芯片的人有福了"意味着如果用户拥有基于CH341芯片的设备并且运行的是Win7系统,他们可以通过这个驱动解决设备连接或功能问题。 标签中的"ch341ser.inf__wi"和"ch341ser.inf_win7"再次强调了这两个INF文件...

    hibernate多表联合查询

    使用HQL进行多表联合查询是非常直观的,我们可以直接使用`FROM`子句来指定要查询的表,然后使用`JOIN`子句来连接不同的表。示例如下: ```java // 假设Customer和Charge实体类已定义好 Session session = ...

    精通hibernate源码ch7

    在本章中,我们将深入探讨Hibernate这一流行的Java对象关系映射(ORM)框架的源码,专注于对象持久化的实现机制。Hibernate使得Java开发者能够轻松地将业务对象与数据库中的记录进行映射,从而极大地简化了数据操作...

    精通hibernate源码ch6

    《精通Hibernate源码Chapter6:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅可以帮助开发者提高开发效率,还...

    CH375WDM.rar_CH375W_CH375WDM.1NF_ch375_ch375wdm.SYS_ch375wdm.s

    1. **CH375硬件接口**:了解CH375的引脚定义、功能及与微控制器的连接方式。 2. **驱动结构**:分析驱动程序的组织结构,包括初始化函数、设备枚举、I/O请求处理等。 3. **USB协议**:掌握USB协议的基础知识,如端点...

Global site tag (gtag.js) - Google Analytics