常用JDBC连接池

2023-10-15 17:33:55 浏览数 (1)

如下整理常用JDBC连接池组件。

HikariCP

针对不同的JDK需要引入对应的HikariCP,详见:Github项目地址 。 以JDK8为例子,在项目中引入如下依赖:

代码语言:javascript复制
<dependency>
   <groupId>com.zaxxer</groupId>
   <artifactId>HikariCP</artifactId>
   <version>4.0.3</version>
</dependency>

简单使用示例:

代码语言:javascript复制
HikariConfig config = new HikariConfig();
config.setJdbcUrl("jdbc:mysql://localhost:3306/simpsons");
config.setUsername("bart");
config.setPassword("51mp50n");
config.addDataSourceProperty("cachePrepStmts", "true");
config.addDataSourceProperty("prepStmtCacheSize", "250");
config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");

HikariDataSource ds = new HikariDataSource(config);

Druid

Druid连接池为监控而生,内置强大的监控功能,监控特性不影响性能,详见:Druid连接池介绍

在项目中添加如下依赖配置:

代码语言:javascript复制
<dependency>
     <groupId>com.alibaba</groupId>
     <artifactId>druid</artifactId>
     <version>1.2.15</version>
</dependency>

简单使用示例:

代码语言:javascript复制
DruidDataSource dataSource = new DruidDataSource();
// 连接数据库的url
dataSource.setUrl("jdbc:mysql://localhost:3306/simpsons");
// 连接数据库的用户名
dataSource.setUsername("bart");
// 连接数据库的密码
dataSource.setPassword("51mp50n");

// 属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有:
// 监控统计用的filter:stat
// 日志用的filter:log4j
// 防御sql注入的filter:wall
dataSource.setFilters("stat");
// 最大连接池数量
dataSource.setMaxActive(20);
// 初始化时建立物理连接的个数,初始化发生在显示调用init方法,或者第一次getConnection时
dataSource.setInitialSize(1);
// 获取连接时最大等待时间,单位毫秒
// 配置了maxWait之后,缺省启用公平锁,并发效率会有所下降,如果需要可以通过配置useUnfairLock属性为true使用非公平锁。
dataSource.setMaxWait(6000);
//dataSource.setMaxIdle(1);

// 有两个含义:
// 1) Destroy线程会检测连接的间隔时间,如果连接空闲时间大于等于minEvictableIdleTimeMillis则关闭物理连接。
// 2) testWhileIdle的判断依据,详细看testWhileIdle属性的说明
dataSource.setTimeBetweenEvictionRunsMillis(60000);
// 连接保持空闲而不被驱逐的最小时间
dataSource.setMinEvictableIdleTimeMillis(300000);

// 建议配置为true,不影响性能,并且保证安全性。
// 申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。
dataSource.setTestWhileIdle(true);
// 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
dataSource.setTestOnBorrow(false);
// 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
dataSource.setTestOnReturn(false);

// 是否缓存preparedStatement,也就是PSCache。
// PSCache对支持游标的数据库性能提升巨大,比如说oracle,在mysql下建议关闭。
dataSource.setPoolPreparedStatements(true);
// 要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。
// 在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100
dataSource.setMaxOpenPreparedStatements(20);

// 异步初始化
dataSource.setAsyncInit(true);

在与Spring框架集成使用时,还支持使用xml文件格式进行配置,参考:DruidDataSource配置 。

Tomcat JDBC Pool

这是Tomcat组件提供的一个连接池,可以单独使用。 关于Tomcat JDBC连接池的使用,每个版本的Tomcat都有专门的说明,以Tomcat 10为例,参考:The Tomcat JDBC Connection Pool 。

在项目中添加如下依赖:

代码语言:javascript复制
<dependency>
    <groupId>org.apache.tomcat</groupId>
    <artifactId>tomcat-jdbc</artifactId>
    <version>10.1.10</version>
</dependency>

简单使用示例:

代码语言:javascript复制
PoolProperties p = new PoolProperties();
p.setUrl("jdbc:mysql://localhost:3306/mysql");
p.setDriverClassName("com.mysql.jdbc.Driver");
p.setUsername("root");
p.setPassword("password");
p.setJmxEnabled(true);
p.setTestWhileIdle(false);
p.setTestOnBorrow(true);
p.setValidationQuery("SELECT 1");
p.setTestOnReturn(false);
p.setValidationInterval(30000);
p.setTimeBetweenEvictionRunsMillis(30000);
p.setMaxActive(100);
p.setInitialSize(10);
p.setMaxWait(10000);
p.setRemoveAbandonedTimeout(60);
p.setMinEvictableIdleTimeMillis(30000);
p.setMinIdle(10);
p.setLogAbandoned(true);
p.setRemoveAbandoned(true);
p.setJdbcInterceptors(
        "org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;" 
        "org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer");
DataSource datasource = new DataSource();
datasource.setPoolProperties(p);

0 人点赞