赛迪网 > IT技术 Java > 架构-与-模式
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

第三方类库--Hibernate + Proxool配置

发布时间:2008.01.24 04:35     来源:赛迪网    作者:ycoe

用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-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>

  好啦,到这里已经把Proxool和Hibernate的配置文件各项说明完了。
          (责任编辑:包春林)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· Java入门--Java怎样调用外部应用程序 (01-23) · J2EE综合--浅谈Java程序员的存储过程 (01-23)
· 设计及设计模式:关于Java权限控制算法 (01-23) · HashMap中的对象根据成员进行自定义排序 (01-23)
· Java入门:java语言中创建和使用日期 (01-23) · JSP指令元素简介 (01-23)
· Java解析网络数据流的三种特殊方法 (01-22) · 实现Web服务器 (01-22)
· 用Java实现断点续传(HTTP) (01-22) · socket编程入门 (01-22)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
· 中小企业网站建设存在弊端 手机实名推波助澜
· CIO应如何克服三个关键错误信念 CIO委屈定理
· 五条黄金准则能够让CIO巧妙加薪 CIO焦虑调查
· 网上书店解决方案 深圳边检指挥中心ITSM项目
  IT博客 ·曾剑秋·项立刚·Java学习·网管
  IT技术论坛 ·开发·网管·安全·数据库·系统