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个小时