项目中用到的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个小时