Hibernate + Proxool配置
来源:互联网 发布:公安专业科目考试知乎 编辑:程序博客网 时间:2024/06/05 12:58
用Hibernate自带的连接池性能不太高,而且还存在BUG。因此官方推荐使用c3p0或Proxool连接池。
这里我介绍Hibernate使用Proxool连接池的配置:
首先配置Proxool的配置文件,文件名:Proxool.xml(当然,你也可以用资源文件)
<!-- the proxool configuration can be embedded within your own application's.
Anything outside the "proxool" tag is ignored. -->
<something-else-entirely>
<proxool>
<alias>DBPool</alias>
<driver-url>jdbc:mysql://localhost:3306/WebShop?user=root&password=&useUnicode=true&characterEncoding=GB2312</driver-url>
<driver-class>org.gjt.mm.mysql.Driver</driver-class>
<driver-properties>
<property name="user" value="root"/>
<property name="password" value=""/>
</driver-properties>
<maximum-connection-count>10</maximum-connection-count>
<house-keeping-test-sql>select CURRENT_DATE</house-keeping-test-sql>
</proxool>
</something-else-entirely>
这里有几点要说明的
<alias>是连接池的别名,在JDBC中可以用DriverManager.getConnection("Proxool.DBPool");取得一个连接(但你得先在程序运行时先加载它)。
<driver-url>是数据库地址,不用说也明白了。但后面还加有一段参数useUnicode=true&characterEncoding=GB2312这是设定连接的参数,这里是定义了连接使用的编码为GB2312,这是为了解决数据库存取中的乱码问题
<driver-class>这是JDBC使用的数据库驱动类,对于不同的数据库,有不同的驱动类支持,一般官方会提供
<driver-properties>里面的都很简单啦,不说了。
还有就是<maxmum-connection-count>是设置连接池内生成的最大连接数,一般中型的网站用10个连接就足够了。
好啦,Proxool配置完成,把它放在WEB-INF/classes下面(放在哪都没关系,只要让路径Path包含着就行)!
下面是Hibernate的配置:这里我们还是用XML文件,因为它配置映射有独特的昧力
hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- Database connection settings -->
<property name="hibernate.connection.provider_class">org.hibernate.connection.ProxoolConnectionProvider</property>
<property name="hibernate.proxool.pool_alias">DBPool</property>
<property name="hibernate.proxool.xml">Proxool.xml</property>
<!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- Echo all executed SQL to stdout -->
<property name="show_sql">false</property>
<!-- Drop and re-create the database schema on startup
<property name="hbm2ddl.auto">create</property>
-->
<mapping resource="Orders.hbm.xml"/>
<mapping resource="Users.hbm.xml"/>
</session-factory>
</hibernate-configuration>
Hibernate3版本的配置都使用<property>
首先hibernate.connection.provider_class定义Hibernate的连接加载类,这里Proxool连接池是用这个,不同的连接池有不同的加载类,可以查阅Hibernate文档获取相关信息
hibernate.proxool.pool_alias这里就是用我们上面提到的连接池的别名
hibernate.proxool.xml是向Hibernate声明连接池的配置文件位置,可以用相对或绝对路径,用相对路径时要注意一定在要Path范围内!不然会抛出异常。
dialect是声明SQL语句的方言
show_sql定义是否显示Hibernate生成的SQL语言,一般在调试阶段设为true,完成后再改成false,这样有利于调试。
hbm2ddl.auto是声明是否使用hbm2 ddl工具,也就是根据映射文件生成SQL的DDL文件。
<mapping >这个可是个好东西了,方便的用于映射。resource是定义映射文件的位置,和Proxool.xml一样。
不同的连接池用不同的配置,下面提供c3p0连接池在Hibernate中的配置:
<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<property name="hibernate.c3p0.max_size">20</property>
<property name="hibernate.c3p0.min_size">5</property>
<property name="hibernate.c3p0.timeout">120</property>
<property name="hibernate.c3p0.max_statements">100</property>
<property name="hibernate.c3p0.idle_test_period">120</property>
<property name="hibernate.c3p0.acquire_increment">2</property>
本文转自:http://www.cnblogs.com/ycoe/archive/2006/03/20/353677.html
- Hibernate+Proxool配置
- Spring+Hibernate+Proxool配置
- Hibernate + Proxool(连拉池)配置
- Hibernate + Proxool配置
- Hibernate配置proxool
- hibernate中配置proxool
- hibernate中配置proxool
- hibernate、proxool配置
- Hibernate+proxool 配置
- hibernate proxool 配置
- hibernate proxool的文件配置
- Hibernate + Proxool 配置,连接问题解决
- struts2 - spring -hibernate -proxool配置
- Hibernate 配置Proxool连接池
- hibernate 配置proxool连接池
- 简单介绍Hibernate配置Proxool
- Hibernate + Proxool配置 并监控proxool连接池
- 在Hibernate中配置Proxool连接池
- Spring 2.5.6新特性之packagesToScan
- java笔试题
- C++试题二
- jsp九大隐士对象
- SQL Server CHARINDEX和PATINDEX
- Hibernate + Proxool配置
- 上海2009英雄会归来
- 定制脚本 runstats
- java基础教程之异常
- 笔试题
- ASP二级联运菜单
- 开博啦
- 关于B/S和C/S架构的探析
- innerHTML与outerHTML的区别