Tomcat 连接池调优
性能较好的Tomcat 配置文件内容
<Context>
<Resource name="jdbc/pgsql" type="javax.sql.DataSource" driverClassName="org.postgresql.Driver"
url="jdbc:postgresql://10.14.196.190:5432/foo"
username="sdbadmin"
password="sdbadmin"
factory="org.apache.tomcat.jdbc.pool..DataSourceFactory"
maxActive="600"
maxIdle="600"
minIdle="600"
initialSize="400"
timeBetweenEvictionRunsMillis="30000"
minEvictableIdleTimeMillis="1800000"
removeAbandoned="true"
removeAbandonedTimeout="180"
testOnBorrow="true"
maxWait="300000"
logAbandoned="true"
testOnReturn="false"
validationQuery="SELECT 1"
/> <ResourceLink global="jdbc/pgsql"
name="jdbc/pgsqlDB"
type="javax.sql.DataSource"
/> </Context>
Resource 重要参数说明:
factory 使用哪种连接池的库
maxActive 连接池的最大连接上限
maxIdle 最大空闲连接数,空闲的连接如果超过 minEvictableIdleTimeMillis 参数设置的值,空闲连接将被释放
minIdle 最小空闲连接数
initialSize 初始化连接数
timeBetweenEvictionRunsMillis 多长时间去检查一次连接池的空闲连接,并且发现空闲连接的空闲时间超过了 minEvictableIdleTimeMillis 设置时间后,直接将空闲连接断开,直到空闲连接数为 minIdle 数为止
minEvictableIdleTimeMillis 这个参数要和 timeBetweenEvictionRunsMillis 参数混合使用
removeAbandoned 是否清理超过 removeAbandonedTimeout 设置时间的活动连接
removeAbandonedTimeout 活动连接的最大空闲时间
testOnBorrow 从连接池中借出连接前,是否对该连接进行正确性校验,连接正常才会出池,如果连接已经失效,将会把失效连接清除,并且重新申请新的连接。该参数可以保证成功借出的连接都是处于活动状态。该参数必须要和 validationQuery 参数配合使用,如果 validationQuery 参数为空字符串,该参数将不生效。
maxWait 连接池用完后,申请新连接的等待时间
logAbandoned 连接池回收空闲的活动连接时是否打印日志
testOnReturn 将连接返回连接池时,是否对该连接进行正确性校验,如果连接失效,将清除该连接,如果连接正常,则回池。该参数必须和 validationQuery 参数配合使用。默认值为 false
validationQuery 探测连接健壮性的模板SQL
老的tomcat 连接池的配置,性能不好
<Context>
<Resource name="jdbc/pgsql" type="javax.sql.DataSource" driverClassName="org.postgresql.Driver"
url="jdbc:postgresql://10.14.196.190:5432/foo"
username="sdbadmin"
password="sdbadmin"
factory="org.apache.tomcat.jdbc.pool..DataSourceFactory"
maxActive="1000"
maxIdle="-1"
minIdle="600"
initialSize="500"
timeBetweenEvictionRunsMillis="0"
removeAbandoned="true"
removeAbandonedTimeout="1000"
/> <ResourceLink global="jdbc/pgsql"
name="jdbc/pgsqlDB"
type="javax.sql.DataSource"
/>
</Context>
该配置的问题
maxIdle 设置-1 是错误,tomcat 会报告该参数大于maxActive ,然后设置为与 maxActive 相同的值
timeBetweenEvictionRunsMillis 由于没有设置 validationQuery 参数,所以不生效
removeAbandoned 由于没有设置 validationQuery 参数,所以不生效
removeAbandonedTimeout 由于没有设置 validationQuery 参数,所以不生效
最新文章
- 【Android】实现XML解析的几种技术
- VPN断线原因解析- ADSL惹的祸
- 转载:第四弹!全球首个微信小程序(应用号)开发教程!通宵吐血赶稿,每日更新!
- PHP 设计模式 笔记与总结(9)数据对象映射模式
- 使用Xcode GPU Frame Caputre教程
- S1:变量
- Codeforces Round #307 (Div. 2) B. ZgukistringZ 暴力
- 使用Redis的理由
- 来自投资银行的20个Java面试题
- CSS样式的优势
- MySQL性能分析脚本
- JS实现以日历形式显示当前时间
- python 中os.path.join 双斜杠的解决办法
- javascript内置对象速查(一)
- Relation Extraction中SVM分类样例unbalance data问题解决 -松弛变量与惩罚因子
- 原生js轮播图实现
- Linux记录-CentOS配置Docker
- phpstudy 配置 memcached / memcache
- CentOS搭建Vsftpd服务器
- 关系型数据库之Mysql
热门文章
- csslint
- Golang RPC 性能测试
- s:iterator
- zsh 的简单介绍
- 最简单ajax,$.post()用法
- html body div height: 100%;
- 常见的LINUX发行版安装libiconv库方法
- BZOJ 1619 [Usaco2008 Nov]Guarding the Farm 保卫牧场:dfs【灌水】
- ORM学习 一 : JPA JDBC
- 八、MyEclipse多次重装、删除注册表、重装系统激活都不成功,终极解决方法 - imsoft.cnblogs