首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

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

2012-09-02 
项目中用到的Proxool0.9.1数据连接池配置实践1:先是配置文件:Xml代码?xml version1.0 encodinggb231

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

热点排行