您的位置:

hikaricpdruid使用详解

一、背景介绍

在日常的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的使用方法和优劣。