`

有关Hibernate连接池不够的问题

阅读更多

最近在做一个项目(spring+hibernate)时用到了连接池,我用的是proxool连接池,配置如下:

 

//==============数据源==============

<bean id="dataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource">
        <property name="driver" value="${jdbc.driverClassName}" />
        <property name="driverUrl" value="${jdbc.url}" />
        <property name="user" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        <property name="alias" value="drpdb" />
        <property name="maximumConnectionCount" value="20" />       
        <property name="minimumConnectionCount" value="1" />
        <property name="delegateProperties" value="user=${jdbc.username},password=${jdbc.password}" />
        <property name="houseKeepingSleepTime" value="50000" />
        <property name="prototypeCount" value="5" />
        <property name="maximumConnectionLifetime" value="18000000" />
        <property name="maximumActiveTime" value="60000" />
       
        <property name="simultaneousBuildThrottle" value="5" />
        <property name="recentlyStartedThreshold" value="40000" />       
        <property name="overloadWithoutRefusalLifetime" value="50000" />
        <property name="houseKeepingTestSql" value="select CURRENT_DATE" />
        <property name="verbose" value="true" />
        <property name="trace" value="true" />
        <property name="statistics" value="10s,1m,1d" />
        <property name="statisticsLogLevel" value="ERROR" />
       
      </bean>

 

<!--Hibernate TransactionManager-->
    <bean id="myTransactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>
       
    <bean
        class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor" />

 

 

//============sessionFactory===========

<bean id="sessionFactory"
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="configurationClass">
            <value>org.hibernate.cfg.AnnotationConfiguration</value>
        </property>
       
        <!--property name="hibernateProperties">
            <value>hibernate.hbm2ddl.auto=update</value>           
        </property-->
       
        <property name="hibernateProperties">
            <props>
               
                <prop key="hibernate.show_sql">true</prop>
            </props>
        </property>
       
        <property name="configLocation">
            <value>classpath:hibernate.cfg.xml</value>
        </property>
       
       
    </bean>

 

我照此方法配置但用不了多时连接池就不够用了,最近发现是在hibernate.cfg.xml文件中少了一个属性

就是这句:

 

<property name="hibernate.connection.release_mode">auto</property>

 

加上这句就可以了,哈哈,找了几天终于解决了!


Hibernate JDBC和连接(connection)属性

属性名 用途
hibernate.jdbc.fetch_size 非零值,指定JDBC抓取数量的大小 (调用Statement.setFetchSize() ).
hibernate.jdbc.batch_size 非零值,允许Hibernate使用JDBC2的批量更新.

取值 建议取530 之间的值

hibernate.jdbc.batch_versioned_data 如果你想让你的JDBC驱动从executeBatch() 返回正确的行计数 , 那么将此属性设为true (开启这个选项通常是安全的). 同时,Hibernate将为自动版本化的数据使用批量DML. 默认值为false .

eg. true | false

hibernate.jdbc.factory_class 选择一个自定义的Batcher . 多数应用程序不需要这个配置属性.

eg. classname.of.Batcher

hibernate.jdbc.use_scrollable_resultset 允许Hibernate使用JDBC2的可滚动结果集. 只有在使用用户提供的JDBC连接时,这个选项才是必要的, 否则Hibernate会使用连接的元数据.

取值 true | false

hibernate.jdbc.use_streams_for_binary 在JDBC读写binary (二进制)serializable (可序列化) 的类型时使用流(stream)(系统级属性).

取值 true | false

hibernate.jdbc.use_get_generated_keys 在数据插入数据库之后,允许使用JDBC3 PreparedStatement.getGeneratedKeys() 来获取数据库生成的key(键)。需要JDBC3+驱动和JRE1.4+, 如果你的数据库驱动在使用Hibernate的标 识生成器时遇到问题,请将此值设为false. 默认情况下将使用连接的元数据来判定驱动的能力.

取值 true|false

hibernate.connection.provider_class 自定义ConnectionProvider 的类名, 此类用来向Hibernate提供JDBC连接.

取值 classname.of.ConnectionProvider

hibernate.connection.isolation 设置JDBC事务隔离级别. 查看java.sql.Connection 来了解各个值的具体意义, 但请注意多数数据库都不支持所有的隔离级别.

取值 1, 2, 4, 8

hibernate.connection.autocommit 允许被缓存的JDBC连接开启自动提交(autocommit) (不建议).

取值 true | false

hibernate.connection.release_mode 指定Hibernate在何时释放JDBC连接. 默认情况下,直到Session被显式关闭或被断开连接时,才会释放JDBC连接. 对于应用程序服务器的JTA数据源, 你应当使用after_statement , 这样在每次JDBC调用后,都会主动的释放连接. 对于非JTA的连接, 使用after_transaction 在每个事务结束时释放连接是合理的. auto 将为JTA和CMT事务策略选择after_statement , 为JDBC事务策略选择after_transaction .

取值 auto (默认) | on_close | after_transaction | after_statement

注意,这些设置仅对通过SessionFactory.openSession 得到的Session 起作用。对于通过SessionFactory.getCurrentSession 得到的Session ,所配置的CurrentSessionContext 实现控制这些Session 的连接释放模式。

hibernate.connection.<propertyName> 将JDBC属性propertyName 传递到DriverManager.getConnection() 中去.
hibernate.jndi.<propertyName> 将属性propertyName 传递到JNDI InitialContextFactory 中去.

 

 

分享到:
评论

相关推荐

    hibernate连接池.doc

    在Java的持久化框架Hibernate中,连接池是一个关键组件,用于优化数据库的连接管理,减少创建和关闭数据库连接的开销。文档中的标题和描述提到了Hibernate对第三方连接池的支持,特别是C3P0、Proxool和DBCP。下面...

    Hibernate连接池的三种配置方式

    标题中的“Hibernate连接池的三种配置方式”指的是Hibernate框架中常用的三种数据库连接池实现,分别是:DBCP (BasicDataSource),C3P0,以及Proxool。这些连接池的目的是管理和优化数据库连接的创建、分配和回收,...

    数据库连接池以及hibernate对各种连接池的整合

    标题提到的“数据库连接池以及hibernate对各种连接池的整合”是指在Java应用中,特别是使用Hibernate作为持久层框架时,如何集成和配置不同的数据库连接池技术。以下是一些主要的开源数据库连接池及其特点: 1. **...

    hibernate配置连接池大全

    总结,Hibernate连接池的配置是优化数据库操作性能的关键步骤。正确选择和配置连接池,可以大大提高系统的响应速度和稳定性。本文以Proxool为例,介绍了配置过程,并简要提及了其他常见的连接池,希望能为你的项目...

    java hibernate中各种连接池比较

    Java Hibernate 中的各种连接池在应用程序开发中扮演着关键角色,它们负责管理数据库连接,提高性能并减少资源消耗。本文将对比分析三个常见的开源数据连接池:C3P0、DBCP 和 Proxool,并深入探讨它们的主要参数和...

    Hibernate2和Hibernate3连接池配置.doc

    在Hibernate2中,Apache的DBCP连接池是官方推荐的,但在Hibernate3中,由于存在一些已知的问题,DBCP不再被推荐使用。官方建议如果在Hibernate3中必须使用DBCP,最好通过JNDI(Java Naming and Directory Interface...

    hibernate连接池配置

    为了提高数据库操作的效率和管理数据库连接,Hibernate支持集成第三方连接池。连接池是一种资源管理技术,它可以有效地复用数据库连接,减少创建和销毁连接的开销。在Hibernate中,官方推荐的连接池有C3P0、Proxool...

    HIbernate连接池配置总结基于第三方c3p0和proxool

    Hibernate连接池是一种管理数据库连接的机制,它允许应用程序重用已打开的数据库连接,避免频繁地创建和关闭连接,从而提高数据库操作的性能和效率。连接池在初始化时会创建一定数量的连接,当应用程序需要数据库...

    hibernate配置数据库连接池的三种方法

    数据库连接池是应用程序管理和维护数据库...总的来说,合理配置和使用数据库连接池是优化Hibernate应用性能的关键步骤之一,它有助于提升系统整体的运行效率,减少资源浪费,同时也便于监控和管理数据库连接的状态。

    hibernate使用c3p0连接池的资料

    ### hibernate使用c3p0连接池的知识点详解 #### 一、Hibernate与C3P0连接池概述 - **Hibernate**: 是一个全功能的Java持久层框架,它提供了对象关系映射(ORM)功能,使得Java应用可以方便地与数据库进行交互。...

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

    本文将深入探讨Hibernate与Proxool连接池的配置,以及在配置过程中可能遇到的问题。 **1. Proxool简介** Proxool是一个开源的数据库连接池实现,它提供了动态、可扩展的连接池管理服务。通过Proxool,开发者可以...

    Hibernate3.2连接池

    Hibernate 3.2虽然自带了一个连接池,但由于性能和稳定性问题,官方并不推荐使用。它默认的连接池在处理大量请求或需要高容错能力的应用场景下表现不佳,可能存在BUG。尽管如此,配置方法如下: ```xml ...

    Hibernate 连接池的配置方式.doc

    这篇文档主要讨论了Hibernate连接池的配置方式,特别是C3P0和Proxool的配置。 首先,Hibernate提供了多种连接池选择,包括dbcp、C3P0和Proxool。然而,由于dbcp存在一些问题,如空连接无法释放的BUG,Hibernate从...

    Hibernate的连接池和数据源配置

    Hibernate支持第三方的连接池,官方推荐的连接池是C3P0,Proxool,以及DBCP。在配置连接池时需要注意的有三点: 一、Apche的DBCP在Hibernate2中受支持,但在Hibernate3中已经不再推荐使用,官方的解释是这个连接池存在...

    hibernate 配置 C3P0 连接池

    最后,`hibernate.c3p0.validate`如果设置为`true`,表示每次从连接池中获取连接前都会进行有效性检查,虽然这会增加一些额外的开销,但可以有效避免使用无效连接的问题。 以上就是在Hibernate中配置C3P0连接池的...

    spring3+hibernate4+springmvc+druid连接池

    【标题】"spring3+hibernate4+springmvc+druid连接池"是一个常见的Java Web开发中的技术栈整合,其中包含了Spring框架的三个主要组件:Spring Core、Spring MVC和Hibernate ORM,以及Druid数据库连接池。这个组合常...

    hibernate结合连接池相关配置

    4. 使用最新的连接池版本,因为每个新版本通常都会包含性能优化和已知问题的修复。 总结,Hibernate结合连接池的配置是一项关键的优化工作,能够显著提升Java应用的数据库操作效率和系统的整体性能。正确选择和配置...

    配置Hibernate使用Proxool连接池

    在Java的Web开发中,数据库连接管理是一个至关重要的环节,特别是在处理高并发场景时,合理的数据库连接池配置能显著提高系统性能。本篇文章将详细讲解...同时,注意定期监控连接池的状态,以便及时发现和解决问题。

Global site tag (gtag.js) - Google Analytics