一、背景介绍
在日常的Java开发中,连接池的选择是非常重要的一部分,一个好的连接池可以为项目提供极大的性能优势。目前比较流行的几个Java数据库连接池技术主要有:c3p0、druid和hikaricp。
二、hikaricp介绍
hikaricp是目前最快的Java数据库连接池,相较于常见的c3p0和druid,hikaricp在高并发下表现更加优秀,且hikaricp的初始化时间更短。
代码示例1:引入hikaricp依赖
<!-- Maven -->
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>4.0.3</version>
</dependency>
三、hikaricp使用
1. 单数据源使用
单数据源使用非常简单,只需要在配置文件中配置相应的数据库链接、账号密码等属性即可。
代码示例2:application.properties文件配置
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/your_database_name?useUnicode=true&characterEncoding=utf8&autoReconnect=true&serverTimezone=GMT%2B8&useSSL=false&allowPublicKeyRetrieval=true
spring.datasource.username=your_username
spring.datasource.password=your_password
# HikariCp配置
spring.datasource.hikari.minimum-idle=5
spring.datasource.hikari.maximum-pool-size=15
spring.datasource.hikari.idle-timeout=30000
spring.datasource.hikari.pool-name=your-pool-name
spring.datasource.hikari.connection-timeout=5000
spring.datasource.hikari.connection-test-query=SELECT 1
spring.datasource.hikari.max-lifetime=60000
2. 多数据源使用
如果需要使用多数据源,则需要在Java配置中配置多个DataSource对象,每个DataSource对应一个数据库链接。
代码示例3:多数据源配置
@Configuration
public class DataSourceConfig {
// 主数据源的配置
@Primary
@Bean(name = "primaryDataSource")
@ConfigurationProperties(prefix = "spring.datasource.primary.hikari")
public DataSource primaryDataSource() {
return DataSourceBuilder.create().type(HikariDataSource.class).build();
}
// 第二个数据源的配置
@Bean(name = "secondDataSource")
@ConfigurationProperties(prefix = "spring.datasource.second.hikari")
public DataSource secondDataSource() {
return DataSourceBuilder.create().type(HikariDataSource.class).build();
}
}
3. 配置druid连接池
如果需要使用druid连接池替代hikaricp,则需要在pom.xml文件中添加druid依赖,并在配置文件中添加对应的配置。
代码示例4:引入druid依赖和配置示例
<!-- Maven -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.3</version>
</dependency>
spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=5
spring.datasource.druid.max-active=20
四、总结
通过本文对hikaricpdruid的详细介绍,你可以清楚地了解到如何选择一个好的Java数据库连接池,以及hikaricp和druid的使用方法和优劣。