WEB开发网
开发学院WEB开发Jsp Hibernate + Proxool配置 阅读

Hibernate + Proxool配置

 2008-01-05 09:28:34 来源:WEB开发网   
核心提示:用Hibernate自带的连接池性能不高,而且还存在BUG,Hibernate + Proxool配置,因此官方推荐使用c3p0或PRoxool连接池,这里我介绍Hibernate使用Proxool连接池的配置:首先配置Proxool的配置文件,但不够深度,用不着每本都用四五百页来写吧...唉,文件名: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</driver-url>
  <driver-class>org.gjt.mm.mysql.Driver</driver-class>
  <driver-properties>
   <property name="user" value="ycoe"/>
   <property name="passWord" value="123456"/>
  </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,这是为了解决数据库存取中的乱码问题(假如数据库没有提供编码设定的话,比如MySQL5.0以前版本)
  <driver-class>这是JDBC使用的数据库驱动类,对于不同的数据库,有不同的驱动类支持,一般官方会提供
  <driver-properties>里面的都很简单啦,不说了。

  还有就是<maxmum-connection-count>是设置连接池内生成的最大连接数

  Proxool配置完成,把它放在WEB-INFclasses下面(放在哪都没关系,只要让路径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> 

  好啦,到这里已经把Proxool和Hibernate的配置文件各项说明完了。
  还有一个就是映射文件,在这里就不再说明了,挺多内容的,可以出一本书了。
  孙卫琴的精通Hibernate里面有很具体的说明

  PS:《精通Hibernate》电子工业出版社  这本书里面的东西在Hibernate3里很多都不行的。Hibernate3版本改了不少东西,连包名都改了。
  这里想骂孙卫琴几句:拜托,不要一年出一本书行不行啊,花点时间,质量放高一点.太不厚道了,难为我把你出的书都认真了<<Tomcat与java web开发技术详解>><<精通Hibernate:Java对象持久化技术详解>><<精通Struts:基于MVC的Java Web设计与开发>>.对于初学者来说不错,但不够深度,用不着每本都用四五百页来写吧...
  唉,要学这些技术,还是得去看看英文版的.

见:
  http://ycoe.cnblogs.com/archive/2006/03/20/353677.Html

Tags:Hibernate Proxool 配置

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接