常用数据库连接池 (DBCP、c3p0、Druid) 配置说明
时间: 2023-07-10 12:22:05 浏览: 150
好的,我会回答你的问题,以下是常用数据库连接池 DBCP、c3p0、Druid 的配置说明:
1. DBCP (Apache Commons DBCP)
DBCP 是 Apache Commons 项目中的一个子项目,它是一个纯 Java 实现的数据库连接池。DBCP 的使用非常简单,只需要引入相关的 jar 包即可。以下是 DBCP 的配置说明:
```
# 最大连接数
maxActive=100
# 最大空闲连接数
maxIdle=30
# 最小空闲连接数
minIdle=10
# 获取连接时的最大等待时间,单位为毫秒
maxWait=10000
# 是否开启自动回收空闲连接的线程
removeAbandoned=true
# 回收超时时间,单位为秒
removeAbandonedTimeout=180
# 是否开启缓存 PreparedStatement,提高性能
poolPreparedStatements=true
# 缓存 PreparedStatement 的最大数量
maxOpenPreparedStatements=100
```
2. c3p0
c3p0 是一个开源的 JDBC 数据库连接池,它实现了数据源和 JNDI 绑定,支持 JDBC3 的 Connection 和 Statement 缓存以及 JDBC4 的自动化管理。以下是 c3p0 的配置说明:
```
# 最大连接数
c3p0.maxPoolSize=100
# 最小连接数
c3p0.minPoolSize=10
# 初始化连接数
c3p0.initialPoolSize=10
# 获取连接时的最大等待时间,单位为毫秒
c3p0.checkoutTimeout=10000
# 是否自动回收超时连接
c3p0.autoCommitOnClose=true
# 是否开启自动回收空闲连接的线程
c3p0.idleConnectionTestPeriod=60
# 回收超时时间,单位为秒
c3p0.maxIdleTime=1800
# 是否开启缓存 PreparedStatement,提高性能
c3p0.cachePreparedStatements=true
# 缓存 PreparedStatement 的最大数量
c3p0.maxStatements=100
```
3. Druid
Druid 是阿里巴巴开源的一个高性能、可扩展、功能强大的数据库连接池。它主要提供了以下功能:监控统计、防御 SQL 注入、批量处理、数据源加密、日志记录等。以下是 Druid 的配置说明:
```
# 最大连接数
druid.maxActive=100
# 最大空闲连接数
druid.maxIdle=30
# 最小空闲连接数
druid.minIdle=10
# 获取连接时的最大等待时间,单位为毫秒
druid.maxWait=10000
# 是否开启自动回收空闲连接的线程
druid.removeAbandoned=true
# 回收超时时间,单位为秒
druid.removeAbandonedTimeout=180
# 是否开启缓存 PreparedStatement,提高性能
druid.poolPreparedStatements=true
# 缓存 PreparedStatement 的最大数量
druid.maxOpenPreparedStatements=100
# 是否开启 SQL 执行监控
druid.stat=true
# 是否开启防御 SQL 注入功能
druid.filters=stat,wall,log4j
```
以上就是常用数据库连接池 DBCP、c3p0、Druid 的配置说明。希望对你有所帮助!
阅读全文