tomcat jdbc连接池配置属性详解之参数说明

driverClassName

数据库驱动类,针对mysql填com.mysql.jdbc.Driver

username 用户名
password

密码

maxActive

最大允许的连接数

maxIdle

最大空闲连接,当idle队列数目超过maxIdle时,归还到连接池的连接就会被释放掉!!

具体参考org.apache.tomcat.jdbc.pool.ConnectionPool类returnConnection方法

当某个连接空闲时间超过minEvictableIdleTimeMillis时就会被释放掉,具体可以查看org.apache.tomcat.jdbc.pool.ConnectionPool类checkIdle方法

minIdle

最小空闲连接,当idle队列数量小于minIdle时将不执行checkIdle方法

initialSize

创建连接池默认连接数目,默认值为10

maxWait

最大等待时间,该值控制着当idle队列没有可用连接,且当前连接数量超过maxActive时就会阻塞等待idle队列有可用连接的最大等待时间

testOnBorrow

从连接池中获取连接时是否需要验证返回连接的有效性,一般不使用,如果使用最好配合validationInterval使用,即validationInterval设置为非零值,validationInterval默认为3000毫秒

testOnConnect

当连接首次创建后是否需要检验连接有效性,一般设置为false,默认值为false

testOnReturn

当连接从busy列表移除添加到idle队列前是否需要校验连接的有效性,

具体参考org.apache.tomcat.jdbc.pool.ConnectionPool类shouldClose方法

testWhileIdle 空闲时是否校验连接的有效性,建议设置为true,这样就可以在连接池空闲时检验所有idle连接的有效性,避免使用到无效的连接。
validationQuery

校验连接有效性时使用的sql语句,比如select 1等

validationQueryTimeout

有效性校验超时时间

timeBetweenEvictionRunsMillis

改参数控制着idle连接校验、释放工作的执行周期

minEvictableIdleTimeMillis

某个连接在被释放前可以空闲的最大时间,但是该事件到了连接也不一定被释放掉,要看当前idle队列中空闲线程数是否大于minIdle值,如果小于就保留,大于则满足释放的条件

removeAbandoned

是否释放busy队列超时的连接,配合removeAbandonedTimeout使用

removeAbandonedTimeout busy队列中某个连接使用时间过长,配合removeAbandoned使用
logAbandoned

控制使用abandon连接时输出对应日志

你可能感兴趣的:(spring,tomcat)