`
longgangbai
  • 浏览: 7357359 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

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< /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的配置文件各项说明完了。 

 


 

分享到:
评论
2 楼 longgangbai 2011-08-31  
xz_dukaikai 写道
大哥,,我想要Hibernate配置proxool的Java代码,,也就是获得session工厂的方法怎么写


如果是要java代码也不难吧,其实说白了proxool只是提供了一个datasource给Hibernate而已,在网上查一下不就知道了吗?获得session工厂的方法是没有变化的.
1 楼 xz_dukaikai 2011-07-11  
大哥,,我想要Hibernate配置proxool的Java代码,,也就是获得session工厂的方法怎么写

相关推荐

    Hibernate Proxool连接池配置总结及常遇问题

    这里,`pool_alias`定义了连接池的别名,`hibernate.proxool.xml`指定了Proxool配置文件的位置,`connection.provider_class`则指明使用Proxool作为连接提供者。 **(3)Proxool配置文件** 创建`ProxoolConf.xml`...

    在Hibernate中配置Proxool连接池

    在上述配置中,我们通过`hibernate.proxool.properties`指定了Proxool的配置文件路径,`hibernate.proxool.pool_alias`设置了连接池的别名,这个别名需要与Proxool配置文件中的alias一致。 接下来,我们需要创建...

    Hibernate 联接池 proxool例子和jar包

    3. 初始化Proxool:在应用启动时,可以通过代码初始化Proxool配置,确保连接池已经准备好。例如: ```java Properties properties = new Properties(); properties.setProperty("proxool.poolName", "my_pool"); ...

    hibernate3+ proxool-0.9.1配置 和proxool-0.9.1.jar

    标题中的“hibernate3+ proxool-0.9.1配置”涉及到的是在Java开发中,使用Hibernate3 ORM框架与Proxool连接池的整合配置。Hibernate3是一款流行的持久层框架,它允许开发者用面向对象的方式来操作数据库,而Proxool...

    Hibernate+Proxool配置

    由于项目需求的需要,我们引入了连接池。...我们采用了Hibernate,所以可以考虑hibernate自带的连接池机制,但是发现效率不高,而且Hibernate也推荐使用c3p0或Proxool连接池,在我们的项目中采用了Proxool

    hibernate4.1.4中hibernate+Proxool无法实现加载Proxool的配置文件解决办法及jar包

    4. **Proxool配置文件**:有时候,Proxool需要一个单独的配置文件(如`proxool.properties`),如果你使用了这个文件,确保它被正确地加载并且包含有效的配置。 5. **编码问题**:如果配置文件是UTF-8编码,但系统...

    SSH.rar_hibernate proxool

    SSH.rar_hibernate proxool 这个压缩包文件主要涉及到的是Java Web开发中的一些核心技术整合,尤其是Hibernate、Struts和Spring框架的集成,以及数据库连接池的配置,特别是Proxool和C3P0的使用。这里我们将深入探讨...

    配置Hibernate使用Proxool连接池

    3. Proxool配置:除了在Hibernate配置文件中设置基本的数据库连接信息,我们还可以在Proxool的配置文件(如proxool.xml)中设置更详细的连接池参数,比如最大连接数、最小空闲连接数、超时时间等,以优化连接池性能...

    hibernate+proxool+Oracle库文件

    标题中的“hibernate+proxool+Oracle库文件”揭示了这个压缩包包含的是一个集成Hibernate ORM框架、Proxool...在实际开发中,还需要根据项目需求配置相应的Hibernate和Proxool的配置文件,以及Oracle数据库的相关设置。

    Spring+Hibernate+Proxool连接池

    -- Proxool配置 --&gt; proxool.poolName=myPool proxool.maxSize=50 proxool.maxIdleTime=600 ``` 在这里,我们设置了数据库的基本连接信息(如驱动、URL、用户名和密码),并提供了Proxool的一些关键...

    hibernate+proxool解决mysql8小时问题(附带jar包)

    3. 配置Proxool:除了在Hibernate配置文件中设置基础属性,还可以通过创建或修改Proxool的配置文件(如`proxool.properties`)来定制更详细的参数,如最大存活时间、老化检查频率等。 4. 使用Hibernate:完成配置后...

    hibernate-proxool-4.3.1.Final.zip

    Hibernate通过配置文件(如hibernate.cfg.xml)可以设置Proxool的相关参数,如最大连接数、最小空闲连接数、超时时间等。 Nebula测试项目中的渐变插件测试线束可能包括测试用例、测试脚本以及相关的测试报告,用于...

    Hibernate - Proxool简单实例

    在Hibernate的配置文件`hibernate.cfg.xml`中,我们需要指定使用Proxool作为连接池,并配置相关参数,如最大连接数、空闲超时等: ```xml &lt;property name="hibernate.connection.provider_class"&gt;org.hibernate....

    proxool+hibernate配置

    proxool与hibernate的配置

    proxool连接池用户名密码加密

    Proxool的加密功能允许我们在配置中使用加密的用户名和密码,确保即使配置文件被泄露,攻击者也无法直接获取到明文的数据库凭据。这增强了系统的安全性,降低了数据泄露的风险。 在提供的压缩包文件中,可能包含了...

    基于ssh的proxool连接池配置

    总之,基于SSH的Proxool连接池配置涉及到Spring、Hibernate和Proxool之间的协作,通过这种方式,我们可以有效地管理和优化数据库连接,提高应用程序的性能和稳定性。在实际开发中,需要根据项目需求调整配置参数,以...

    Proxool 在 Hibernate 中的典型配置

    鉴于Hibernate官方不再支持DBCP并推荐使用Proxool或C3P0,了解Proxool在Hibernate中的配置显得尤为重要。 配置Proxool通常涉及创建一个名为proxool.xml的配置文件,这个文件通常放置在应用程序的src根目录下,与...

    Struts2+spring+hibernate中的proxool连接池配置

    -- Proxool配置 --&gt; ``` 3. **配置Hibernate**: 在Hibernate的配置文件(如`hibernate.cfg.xml`)中,将数据源设置为刚刚创建的Proxool数据源bean。比如: ```xml &lt;hibernate-configuration&gt; ... .....

    SSH (Struts2+Spring3+Hibernate3) +Proxool_亲测成功 费大劲了.zip

    文件`Spring3+Hibernate+Proxool_lj配置试验成功.txt`表明Spring3和Hibernate已经成功地集成了Proxool,这可能涉及到了Spring的`DataSource`配置,通过`&lt;bean&gt;`标签定义一个数据源,然后在Hibernate配置中引用它。...

Global site tag (gtag.js) - Google Analytics