DBCP1.4或1.6依赖的jar包

Java连接MySql用DBCP连接池的实现

DBCP参数说明

Java连接MySql用DBCP连接池的实现

Java连接MySql用DBCP连接池的实现
Java连接MySql用DBCP连接池的实现

代码

DBToolls.java文件

Java连接MySql用DBCP连接池的实现
Java连接MySql用DBCP连接池的实现
测试test.java
Java连接MySql用DBCP连接池的实现

运行结果

Java连接MySql用DBCP连接池的实现

DBCP2以上版本依赖的jar包

Java连接MySql用DBCP连接池的实现

DBCP2配置详细说明

由于commons-dbcp所用的连接池出现版本升级,因此commons-dbcp2中的数据库池连接配置也发生了变化,具体的参数配置说明如下:

常用连接配置

Java连接MySql用DBCP连接池的实现

数据源连接数量配置

Java连接MySql用DBCP连接池的实现
提示: 如果在高负载的系统中将maxIdle的值设置的很低,则你可能会发现在一个新的连接刚刚被创建的时候就立即被关闭了。这是活跃的线程及时关闭连接要比那些打开连接的线程要快,导致空闲的连接数大于maxIdle。高负载系统中maxIdle的最合适的配置值是多样的,但是缺省值是一个好的开始点。

事务属性配置

Java连接MySql用DBCP连接池的实现

数据源连接健康状况检查

Java连接MySql用DBCP连接池的实现
Java连接MySql用DBCP连接池的实现

缓存语句

Java连接MySql用DBCP连接池的实现
这个设置同时作用于预处理语句池. 当一个可用的语句池被创建给每一个连接时,通过以下方法创建的预处理语句将被池化。

public PreparedStatement prepareStatement(String sql)
public PreparedStatement prepareStatement(String sql, int resultSetType, int resultSetConcurrency)
提示 -要确保你的连接会留下一些资源给其他语句。池化预处理语句可能会在数据库中保持他们的游标,可能会引起连接的游标越界,尤其是maxOpenPreparedStatements的值被设置为默认值(无限的),而且一个应用程序可能会为每个连接打开大量不同的预处理语句。为了避免这个问题maxOpenPreparedStatements应该被设置为一个小于连接可以打开的最大游标数的值。
Java连接MySql用DBCP连接池的实现
如果允许访问的话,使用如下代码结构:
Java连接MySql用DBCP连接池的实现
默认值为false,这是一个有着潜在风险的操作,使用不当可能会导致非常严重的后果。(在守护连接已被关闭的情况下,关闭底层连接或者继续使用它),只有在你需要直接访问驱动的特有扩展是可以谨慎使用。

NOTE: 除了最原始那个之外,不要关闭底层连接
Java连接MySql用DBCP连接池的实现

连接泄露回收

Java连接MySql用DBCP连接池的实现

代码

DB2.java文件

Java连接MySql用DBCP连接池的实现
Java连接MySql用DBCP连接池的实现
test.java文件
Java连接MySql用DBCP连接池的实现

执行结果

Java连接MySql用DBCP连接池的实现
需要面试资料的加群748620413

相关文章: