项目中用到的Proxool0.9.1数据连接池配置实践

1:先是配置文件:

Xml代码

<?xml version="1.0" encoding="gb2312"?>  

<!-- the proxool configuration can be embedded within your own application's.   

     Anything outside the "proxool" tag is ignored. -->  

<something-else-entirely>  

    <proxool>  

        <alias>example</alias>  

        <driver-url>  

             jdbc:oracle:thin:@*.*.*.*:1521:****   

        </driver-url>  

        <driver-class>oracle.jdbc.driver.OracleDriver</driver-class>  

        <driver-properties>  

            <property name="user" value="*****" />  

            <property name="password" value="*****" />  

        </driver-properties>  

        <!--最大连接数(默认5个),超过了这个连接数,再有请求时,就排在队列中等候,最大的等待请求数由maximum-new-connections决定 -->  

        <maximum-connection-count>20</maximum-connection-count>  

        <!--最小连接数(默认2个,包含活动的和空闲的)-->  

        <minimum-connection-count>4</minimum-connection-count>  

        <!--proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁 默认30秒-->  

        <house-keeping-sleep-time>30000</house-keeping-sleep-time>  

        <!--没有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的用户连接就不会被接受-->  

        <!-- maximum-new-connections不被推荐使用了,所以用simultaneous-build-throttle来代替了 -->  

        <simultaneous-build-throttle>15</simultaneous-build-throttle>  

        <!--maximum-new-connections>10</maximum-new-connections-->  

        <!--最少保持的空闲连接数(默认2个)-->  

        <prototype-count>2</prototype-count>  

        <!-- maximum-active-time缺省5minutes 172800000毫秒=48小时-->  

        <maximum-active-time>172800000</maximum-active-time>  

        <!-- maximum-connection-lifetime缺省4hours 180000000毫秒=50小时-->  

        <maximum-connection-lifetime>180000000</maximum-connection-lifetime>  

        <!--在使用之前测试-->  

        <test-before-use>false</test-before-use>  

        <!--用于保持连接的测试语句 -->  

         <!-- house-keeping-test-sql>  

             select sysdate from dual   

        </house-keeping-test-sql -->  

        <!-- 是否监控sql信息 -->  

        <trace>true</trace>  

        <!-- statistics>10s,1m</statistics -->  

        <!-- statistics-log-level>DEBUG</statistics-log-level -->  

 

    </proxool>  

</something-else-entirely>  

 

注释:(以上的数据连接IP和用户名密码根据自己的实际情况填写)

 

配置文件里的两行

 

<!-- maximum-active-time缺省5minutes 172800000毫秒=48小时-->

<maximum-active-time>172800000</maximum-active-time>

<!-- maximum-connection-lifetime缺省4hours 180000000毫秒=50小时-->

<maximum-connection-lifetime>180000000</maximum-connection-lifetime>

 

第一个48小时的是设置连接活动的时间,即:你的sql或存储过程执行的时间,估算一下你的应用中的sql或存储过程最长的执行时间a,将这个值设为大于a就行了,这是项目中实际发现的问题经验,我有个sql执行时间超过了5分钟,而原来没有设置这个值,缺省为5分钟,所以我的应用刚起来没问题,跑一段时间,跑到这个sql时执行了一段时间后台就报:

 

java.sql.SQLException: Couldn't perform the operation prepareStatement: You can't perform any operations on this connection. It has been automatically closed by Proxool for some reason (see logs).

 

这个错误,后来去官方网页查看Properties发现,如果超过这个值,proxool就会自动kill掉这个连接。

 

      第二个50个小时是设置连接的寿命,这个值理论上应该大于连接的活动时间限制,不然活动时间限制就没有意义了,所以设为了50个小时

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值