本章任务
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)得到这些信息.
分享到:
相关推荐
CH08Hibernate框架介绍.ppt
在ch8数据库连接池这个章节中,你可以找到如何配置和使用数据库连接池的示例代码,这对于优化Web应用程序的性能至关重要。 其次,"解决中文乱码"是Web开发中常遇到的问题。由于字符编码不一致,可能导致中文显示为...
《Android OPhone开发完全讲义源码Ch05》是一份深入探讨Android OPhone平台开发的教程资料,其中包含了第五章的源代码。这个压缩包是开发者和学习者宝贵的资源,帮助他们理解并实践Android OPhone应用的开发过程。...
ch战略领袖SouthWesternCollege战略讲义实用PPT学习教案.pptx
- hibernate.cfg.xml:这是Hibernate的主配置文件,定义了数据库连接信息、JDBC驱动等。 - Mapping文件(.hbm.xml):对象-关系映射文件,描述了Java类与数据库表的对应关系。 3. 实体类(Entity)与持久化: - ...
1. Hibernate配置:包括XML配置文件(hibernate.cfg.xml)的设置,数据库连接参数,以及实体类和数据库表的映射配置。 2. Session工厂与Session:解释如何创建SessionFactory对象,它是Session的工厂,而Session是...
《精通Hibernate源码Chapter5:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅能帮助开发者提高工作效率,还能...
数据库ch05数据库ch05
在本案例的ch05目录中,可能包含了配置文件(如hibernate.cfg.xml)、实体类、映射文件(.hbm.xml)以及与数据库交互的DAO。 **Spring** 是一个全面的后端应用程序框架,涵盖了依赖注入(DI)、AOP(面向切面编程)...
- **配置文件**:通常使用 `hibernate.cfg.xml` 文件来配置 Hibernate 的各种属性,如数据库连接信息、方言(Dialect)、缓存配置等。 - **映射文件**:每个实体类都需要有一个对应的映射文件(`.hbm.xml`),用于...
在`CH4Hibernate2`项目中,你可以通过解压文件并导入到MyEclipse或Eclipse中,然后配置合适的数据库连接和依赖(如Hibernate库),修改相关路径,就可以运行示例代码,体验这些关系在实际操作中的运用。通过增删改查...
《精通Hibernate源码Chapter4:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅可以帮助开发者提高开发效率,还...
测试Hibernate数据库ch03.sql
Hibernate的配置涉及多个方面,包括数据库连接信息、实体类路径、缓存设置等。配置文件通常为hibernate.cfg.xml,其中需明确指定JDBC驱动、URL、用户名和密码。此外,还可以通过编程方式进行动态配置。 3. **...
《精通Hibernate源码Chapter1:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅可以帮助开发者更好地利用其功能...
"使用这个芯片的人有福了"意味着如果用户拥有基于CH341芯片的设备并且运行的是Win7系统,他们可以通过这个驱动解决设备连接或功能问题。 标签中的"ch341ser.inf__wi"和"ch341ser.inf_win7"再次强调了这两个INF文件...
使用HQL进行多表联合查询是非常直观的,我们可以直接使用`FROM`子句来指定要查询的表,然后使用`JOIN`子句来连接不同的表。示例如下: ```java // 假设Customer和Charge实体类已定义好 Session session = ...
在本章中,我们将深入探讨Hibernate这一流行的Java对象关系映射(ORM)框架的源码,专注于对象持久化的实现机制。Hibernate使得Java开发者能够轻松地将业务对象与数据库中的记录进行映射,从而极大地简化了数据操作...
《精通Hibernate源码Chapter6:Java对象持久化技术详解》 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅可以帮助开发者提高开发效率,还...
1. **CH375硬件接口**:了解CH375的引脚定义、功能及与微控制器的连接方式。 2. **驱动结构**:分析驱动程序的组织结构,包括初始化函数、设备枚举、I/O请求处理等。 3. **USB协议**:掌握USB协议的基础知识,如端点...