Hibernate + Proxool配置

用Hibernate自带的连接池性能不太高,而且还存在BUG。因此官方推荐使用c3p0或Proxool连接池。
这里我介绍Hibernate使用Proxool连接池的配置:

首先配置Proxool的配置文件,文件名:Proxool.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 > DBPool </ alias >
    
< driver-url > jdbc:mysql://localhost:3306/WebShop?user=root &amp; password= &amp; useUnicode=true &amp; 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&amp; characterEncoding=GB2312这是设定连接的参数,这里是定义了连接使用的编码为GB2312,这是为了解决数据库存取中的乱码问题
<driver-class>这是JDBC使用的数据库驱动类,对于不同的数据库,有不同的驱动类支持,一般官方会提供
<driver-properties>里面的都很简单啦,不说了。

还有就是<maxmum-connection-count>是设置连接池内生成的最大连接数,一般中型的网站用10个连接就足够了。


好啦,Proxool配置完成,把它放在WEB-INF/classes下面(放在哪都没关系,只要让路径Path包含着就行)!

下面是Hibernate的配置:这里我们还是用XML文件,因为它配置映射有独特的昧力
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 >
        
<!--  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中的配置:

c3p0配置

  
< 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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值