有关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 中去.

 

 

你可能感兴趣的:(spring,sql,Hibernate,bean,jdbc)