Spring Boot实战 | 如何整合高性能数据库连接池HikariCP

news2025/7/19 15:54:36

专栏集锦,大佬们可以收藏以备不时之需

Spring Cloud实战专栏:https://blog.csdn.net/superdangbo/category_9270827.html

Python 实战专栏:https://blog.csdn.net/superdangbo/category_9271194.html

Logback 详解专栏:https://blog.csdn.net/superdangbo/category_9271502.html

tensorflow专栏:https://blog.csdn.net/superdangbo/category_8691332.html

Redis专栏:https://blog.csdn.net/superdangbo/category_9950790.html

1024程序员节特辑文章:

1024程序员狂欢节特辑 | ELK+ 协同过滤算法构建个性化推荐引擎,智能实现“千人千面”

1024程序员节特辑 | 解密Spring Cloud Hystrix熔断提高系统的可用性和容错能力

1024程序员节特辑 | ELK+ 用户画像构建个性化推荐引擎,智能实现“千人千面”

1024程序员节特辑 | OKR VS KPI谁更合适?

1024程序员节特辑 | Spring Boot实战 之 MongoDB分片或复制集操作

Spring实战系列文章:

Spring实战 | Spring AOP核心秘笈之葵花宝典

Spring实战 | Spring IOC不能说的秘密?

国庆中秋特辑系列文章:

国庆中秋特辑(八)Spring Boot项目如何使用JPA

国庆中秋特辑(七)Java软件工程师常见20道编程面试题

国庆中秋特辑(六)大学生常见30道宝藏编程面试题

国庆中秋特辑(五)MySQL如何性能调优?下篇

国庆中秋特辑(四)MySQL如何性能调优?上篇

国庆中秋特辑(三)使用生成对抗网络(GAN)生成具有节日氛围的画作,深度学习框架 TensorFlow 和 Keras 来实现

国庆中秋特辑(二)浪漫祝福方式 使用生成对抗网络(GAN)生成具有节日氛围的画作

国庆中秋特辑(一)浪漫祝福方式 用循环神经网络(RNN)或长短时记忆网络(LSTM)生成祝福诗词

目录

  • 1、HikariCP发展背景和适用场景
  • 2、HikariCP特点
  • 3、HikariCP参数说明
  • 4、Spring Boot整合HikariCP实战
  • 5、HikariCP和其他数据库连接池对比
  • 6、HikariCP常见问题汇总

在这里插入图片描述

1、HikariCP发展背景和适用场景

HikariCP 是一款高性能的数据库连接池,由 derby 项目的创始人兼首席开发人员山姆·柯曼(Sam Covey)开发。HikariCP 的开发始于 2014 年,并在 2016 年发布了首个稳定版本。自此,HikariCP 受到了许多开发者和企业的青睐,逐渐成为一款流行的数据库连接池。
适用场景:
HikariCP 适用于以下场景:

  1. 高性能需求的应用:需要快速处理大量数据的应用,例如高性能的 Web 应用、数据分析应用等。
  2. 高并发场景:需要支持大量用户同时访问的应用,如电商、社交平台等。
  3. 低延迟要求:对数据处理速度有较高要求的应用,例如金融、实时通信等场景。
    HikariCP 的优势在于其高性能、简单易用和兼容性强,可以满足各种场景下使用。在选择连接池时,可以根据实际需求和预算考虑 HikariCP 和其他连接池。

官方资料:
HikariCP 的官方文档提供了详细的使用说明和配置选项,可以帮助开发者快速上手和深入了解 HikariCP。官方文档地址:https://hikari.readthedocs.io/en/latest/
社区:
HikariCP 有一个活跃的社区,开发者可以在社区中提问、分享经验和解决问题。社区地址:https://github.com/hikari-db/hikari

https://github.com/brettwooldridge/HikariCP

2、HikariCP特点

HikariCP 是一个高性能的 JDBC 数据库连接池。它旨在提供最佳的性能、可扩展性和易用性。以下是关于 HikariCP 的一些关键特性:

  1. 性能:HikariCP 被设计为提供最高性能的连接池。它通过使用直接连接、预处理语句池、JDBC 4.0 的 Statement caching 以及连接池参数的优化来提高性能。
  2. 可扩展性:HikariCP 具有可扩展的架构,可以轻松地集成到各种应用程序中。它支持可插拔的连接工厂、事务管理器、SSL 处理器等。
  3. 易用性:HikariCP 提供了一个简单易用的 API,使开发人员可以轻松地配置和监控连接池。
  4. 监控:HikariCP 具有内置的监控和诊断功能,可以帮助开发人员诊断和解决问题。
  5. 安全:HikariCP 支持 SSL 和加密,可以帮助保护数据传输的安全性。
    总的来说,HikariCP 是一个高性能、可扩展、易用且安全的 JDBC 连接池,是许多应用程序开发人员的首选。

3、HikariCP参数说明

HikariCP 是一个高性能的 JDBC 连接池,它具有多种可配置的参数,以满足不同场景的需求。以下是 HikariCP 的一些重要配置参数及其说明:

  1. jdbcUrl:数据库连接字符串,用于指定数据库的地址、端口、用户名和密码等。
  2. usernamepassword:数据库的用户名和密码。
  3. maximumPoolSize:连接池的最大容量。当连接池中的可用连接数达到此值时,新的连接请求将被拒绝。
  4. connectionTimeout:连接池的超时时间,单位为毫秒。当连接池中的连接空闲时间超过此值时,连接将被关闭。
  5. idleTimeout:空闲连接的超时时间,单位为毫秒。当空闲连接空闲时间超过此值时,连接将被关闭。
  6. maxLifetime:连接的最大生命周期,单位为毫秒。当连接的空闲时间超过此值时,连接将被关闭。
  7. minimumIdle:连接池中必须保持的最小空闲连接数。
  8. poolName:连接池的名称,用于标识连接池。
  9. databaseId:数据库的类型,用于指定数据库的类型,例如 MySQL、PostgreSQL 等。
  10. prepStmtCacheSize:预处理语句缓存大小。
  11. prepStmtCacheTimeout:预处理语句缓存超时时间,单位为毫秒。
  12. connectionTestQuery:连接测试查询,用于检测连接是否有效。
  13. autoCommit:自动提交事务。
  14. maximumPoolSize:连接池的最大连接数。
  15. sqlParserEnabled:是否启用 SQL 解析器。
  16. properties:连接池的属性,例如 cachePrepStmtsinitSql 等。
    这些参数可以根据实际需求进行配置,以达到最佳性能和体验。更多关于 HikariCP 的详细配置信息,可以参考其官方文档:https://hikaricp.zonble.org/configuration.html

在这里插入图片描述

4、Spring Boot整合HikariCP实战

HikariCP 是一个高性能的 JDBC 连接池,它旨在提供最佳的性能、可扩展性和易用性。HikariCP 是 Spring Boot 项目中的一个重要组件,它可以轻松地集成到 Spring Boot 应用程序中。以下是如何在 Spring Boot 项目中使用 HikariCP 以及详细配置参数说明。

  1. 添加依赖
    在 Maven 项目的 pom.xml 文件中,添加 HikariCP 的依赖:
<dependency>  
   <groupId>com.zaxxer</groupId>  
   <artifactId>HikariCP</artifactId>  
   <version>4.0.3</version>  
</dependency>  
  1. 创建数据源配置类
    创建一个配置类,用于配置 HikariCP 连接池。在这个类中,我们需要配置 HikariCP 的连接参数,如数据库 URL、用户名、密码等。
@Configuration  
public class DataSourceConfig {
   @Bean  
   public DataSource dataSource() {  
       // 配置 HikariCP 连接池  
       HikariConfig config = new HikariConfig();  
       config.setJdbcUrl("jdbc:mysql://localhost:3306/test_db");  
       config.setUsername("username");  
       config.setPassword("password");  
         
       // 设置连接池其他配置参数  
       config.setMaximumPoolSize(10);  
       config.setConnectionTimeout(30000);  
       config.setIdleTimeout(600000);  
       config.setMaxLifetime(1800000);  
         
       // 创建 HikariDataSource 实例  
       return new HikariDataSource(config);  
   }  
}
  1. 配置事务管理器
    在 Spring Boot 项目中,我们需要配置一个事务管理器,用于管理数据库事务。我们可以使用 PlatformTransactionManager 来实现。
@Bean  
public PlatformTransactionManager transactionManager(DataSource dataSource) {  
   return new DataSourceTransactionManager(dataSource);  
}
  1. 在服务类中使用数据源
    现在我们可以在服务类中使用数据源来执行数据库操作了。
@Service  
public class UserService {
   @Autowired  
   private DataSource dataSource;
   public List<User> findAll() {  
       try (Connection connection = dataSource.getConnection();  
            PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM user");  
            ResultSet resultSet = preparedStatement.executeQuery()) {
           List<User> users = new ArrayList<>();  
           while (resultSet.next()) {  
               users.add(new User(resultSet.getInt("id"), resultSet.getString("name")));  
           }  
           return users;  
       }  
   }  
}

在上面的示例中,我们创建了一个 DataSourceConfig 类来配置 HikariCP 连接池,并在 UserService 类中使用数据源来执行数据库操作。
关于 HikariCP 的详细配置参数,可以参考其官方文档:https://hikaricp.zonble.org/configuration.html

5、HikariCP和其他数据库连接池对比

HikariCP 是一款高性能的数据库连接池,与其他连接池相比,它具有以下优势:

  1. 性能:HikariCP 被认为是目前最快的数据库连接池,其性能优于其他连接池,如 C3P0、DBCP 等。据官方数据,HikariCP 的性能是 C3P0 的 25 倍左右。
  2. 代码量:HikariCP 的代码量非常小,只有 100 多行,这使得其执行效率更高,占用 CPU 和内存更少,且 BUG 出现几率较小。
  3. 配置简单:HikariCP 的配置相对简单,而且提供了丰富的配置选项,可以根据实际需求进行定制。
  4. 兼容性:HikariCP 支持多种数据库,如 MySQL、PostgreSQL、Oracle 等。
  5. Spring Boot 支持:Spring Boot 2.0 已经将 HikariCP 作为默认连接池配置。
    与其他连接池的对比:
  6. Druid:Druid 是阿里巴巴开源的一个数据库连接池,性能非常出色,可以满足高并发、高负载的环境。与 HikariCP 相比,Druid 在一些性能指标上略逊于 HikariCP,但依然保持着较高的水平。Druid 的配置相对复杂,但提供了很多高级功能,如密码加密、连接池监控等。
  7. C3P0:C3P0 是一个常用的 JDBC 数据源和连接池实现,其性能和稳定性表现良好。但与 HikariCP 相比,C3P0 在性能上有一定差距,尤其是在并发和负载较高的场景下。C3P0 的配置相对简单,适合中小型项目。
  8. DBCP:DBCP 是 Apache Commons 项目的一个组成部分,提供了一个简单易用的连接池实现。但与 HikariCP 相比,DBCP 在性能和功能上有一定不足,如连接池管理不够灵活,无法满足高并发场景。
    综上所述,HikariCP 是一款高性能、简单易用、兼容性强的数据库连接池,适合各种场景下使用。在选择连接池时,可以根据实际需求和预算考虑 HikariCP 和 Druid。如果对性能要求非常高,可以考虑使用 HikariCP;如果需要更多高级功能,可以选择 Druid。

6、HikariCP常见问题汇总

HikariCP 作为一款高性能的数据库连接池,虽然在许多场景下表现优秀,但仍然可能遇到一些问题。以下是一些常见的 BUG 及相应的解决方法:

  1. 连接失败或连接超时:
    在使用 HikariCP 过程中,可能会遇到连接失败或连接超时的问题。这通常是由于数据库配置错误、网络问题或数据库服务器本身的问题导致的。
    解决方法:
  • 检查数据库配置,确保配置正确。
  • 检查网络连接,确保可以正常连接到数据库服务器。
  • 如果问题仍然存在,可能是数据库服务器本身的问题,需要联系数据库管理员进行处理。
    以下是一个简单的示例,演示了如何配置 HikariCP 连接 MySQL 数据库:
import com.zaxxer.hikari.HikariConfig;  
import com.zaxxer.hikari.HikariDataSource;
public class HikariCPDemo {  
   public static void main(String[] args) {  
       HikariConfig config = new HikariConfig();  
       config.setJdbcUrl("jdbc:mysql://localhost:3306/test");  
       config.setUsername("root");  
       config.setPassword("123456");  
       config.setMaximumPoolSize(10);  
       config.setConnectionTimeout(3000);
       HikariDataSource dataSource = new HikariDataSource(config);  
       // 使用数据源  
   }  
}
  1. 数据库连接数过多:
    在某些情况下,可能会出现数据库连接数过多的问题,导致系统资源不足。
    解决方法:
  • 检查连接池配置,确保最大连接数设置合理。
  • 如果问题仍然存在,可能需要调整数据库服务器的资源配置,或者优化应用的代码,减少数据库连接的使用。
  1. 密码加密失败:
    在使用密码加密时,可能会遇到加密失败的问题。
    解决方法:
  • 检查密码加密配置,确保配置正确。
  • 如果问题仍然存在,可能需要调整加密算法或密码策略。
    以下是一个简单的示例,演示了如何在 HikariCP 中使用密码加密:
import com.zaxxer.hikari.HikariConfig;  
import com.zaxxer.hikari.HikariDataSource;
public class HikariCPDemo {  
   public static void main(String[] args) {  
       HikariConfig config = new HikariConfig();  
       config.setJdbcUrl("jdbc:mysql://localhost:3306/test");  
       config.setUsername("root");  
       config.setPassword("123456");  
       config.setMaximumPoolSize(10);  
       config.setConnectionTimeout(3000);
       // 密码加密  
       config.setPasswordEncoder(new CustomPasswordEncoder());
       HikariDataSource dataSource = new HikariDataSource(config);  
       // 使用数据源  
   }  
}

以上是关于 HikariCP 常见问题及其解决方法的汇总。如果您在使用过程中遇到其他问题,可以在 HikariCP 的 GitHub 仓库中查找相关问题或提交新的 issue。GitHub 仓库地址:https://github.com/hikari-db/hikari

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1127504.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySql第三篇---索引的创建与设计原则

文章目录 MySql第三篇---索引的创建与设计原则索引的声明与使用索引的分类创建索引在已经存在的表上创建索引删除索引 索引的设计原则哪些情况适合创建索引&#xff1f;限制索引的数目哪些情况不适合创建索引&#xff1f; 小结 MySql第三篇—索引的创建与设计原则 索引的声明与…

如何安装Ubuntu20.04(详细图文教程

目录 一.简介 二、需要资源 三、window设置 1、分区 2、启动盘制作 四、ubuntu安装 一.简介 Linux是一种自由和开放源代码的操作系统内核&#xff0c;被广泛应用于各种计算机系统中。它以稳定性、安全性和灵活性而闻名&#xff0c;并成为服务器、嵌入式设备和个人计算机…

如何用BCompare打增量包

一、基本描述 增量包&#xff1a;工程项目中的文件随着开发、更新、迭代过程&#xff0c;更新、修改了部分文件&#xff0c;没必要将所有的文件都更新时&#xff0c;只打包更新、修改了的这部分文件&#xff0c;这样的一个文件包称为增量包。 二、使用场景 在某个大的版本re…

ranger的只读(read)权限引起的

开发人员只要只读权限 在rang中只给了read的权限 ranger的read和select的权限区别 read 权限&#xff1a; read 权限允许用户读取&#xff08;查看&#xff09;文件或目录的内容。 具有 read 权限的用户可以查看文件的内容&#xff0c;读取目录中的文件列表和元数据&#xf…

你真的了解黑客吗?

前言&#xff1a;本文旨在介绍国内外黑客的发展历史&#xff0c;以及作为一名黑客所需的素质和原则 目录 一.黑客概述 二.黑客分类 三.国外黑客的历史 上世纪60年代初 上世纪80年代初 上世纪80年代末 上世纪90年代早期 上世纪90年代末期 2000年后 四.中国黑客的历史 …

【PythonRS】Rasterio库安装+基础函数使用教程

Rasterio是一个Python库&#xff0c;专门用于栅格数据的读写操作。它支持多种栅格数据格式&#xff0c;如GeoTIFF、ENVI和HDF5&#xff0c;为处理和分析栅格数据提供了强大的工具。RasterIO适用于各种栅格数据应用&#xff0c;如卫星遥感、地图制作等。通过RasterIO&#xff0c…

每日一题 1155. 掷骰子等于目标和的方法数(中等,动态规划,前缀和)

涉及到从 n-1 个骰子到 n 个骰子的状态转移&#xff0c;显然用动态规划做对于一共 i 个骰子所能投出来的数字之和为 t 的情况&#xff0c;我们用 dp[i][t] 表示&#xff0c;显然 dp[i][t] Σdp[i - 1][t - j]&#xff0c;其中 j 从 1 到 k。所以对于每一个骰子我们需要 O(targ…

【C++心愿便利店】No.10---C++之模板

文章目录 前言一、泛型编程二、函数模板三、类模板 前言 &#x1f467;个人主页&#xff1a;小沈YO. &#x1f61a;小编介绍&#xff1a;欢迎来到我的乱七八糟小星球&#x1f31d; &#x1f4cb;专栏&#xff1a;C 心愿便利店 &#x1f511;本章内容&#xff1a;函数模板、类模…

Delete `␍`eslintprettier/prettier

将CRLF改为LF 然后就消失了 除此之外,也可以修改git全局配置 git config --global core.autocrlf false

ChatGPT 入门指南:与 AI 进行愉快互动的秘诀大揭秘!

ChatGPT 入门指南&#xff1a;与 AI 进行愉快互动的秘诀大揭秘&#xff01; 嗨&#xff01;大家好&#xff0c;我是你们的互联网好友&#xff0c;今天我要给大家带来一份特别的礼物——《ChatGPT 入门指南》&#xff01;是不是很期待呢&#xff1f;那就跟我一起来揭开与人工智能…

海外跨境商城电商源码-进出口电商平台网站-多语言多商户多货币平台

一、海外跨境商城电商源码简介 海外跨境电商已成为全球经济发展的重要推动力。而海外跨境商城电商源码则是实现全球化电商的关键工具。本文将详细介绍海外跨境商城电商源码及其相关内容。 二、如何理解海外跨境商城电商源码 海外跨境商城电商源码是指一套已经开发好并可直接应用…

windows10下pytorch环境部署留念

pytorch环境部署留念 第一步&#xff1a;下载安装anaconda 官网地址 &#xff08;也可以到清华大学开源软件镜像站下载&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/&#xff09; 我安装的是下面这个&#xff0c;一通下一步就完事儿。 第二步&#x…

【T3】畅捷通T3采购入库单单据预览,提示不能打开数据表。

【问题描述】 畅捷通T3点击采购入库单预览的时候&#xff0c; 提示ufdtprn窗口&#xff0c;不能打开数据库表SD-20230629HHTI_PurRKD。 【解决方法】 经查看提示的数据表为当前计算机名称&#xff0c; 删除计算机名称中横杠后&#xff0c;重启电脑正常。

PC连wifi,网线连接旭日X3派以共享网络

PC电脑连好wifi&#xff0c;找到【控制面板->网络和Internet->网络和共享中心->查看网络状态和任务->更改适配器设置】 找到WLAN&#xff0c;右键【属性->共享】勾上允许&#xff0c;然后【确定】。 现在去与PC通过网线连接好的X3派上配置&#xff1a; 参考&a…

MySQL MVCC机制探秘:数据一致性与并发处理的完美结合,助你成为数据库高手

一、前言 在分析 MVCC 的原理之前&#xff0c;我们先回顾一下 MySQL 的一些内容以及关于 MVCC 的一些简单介绍。&#xff08;注:下面没有特别说明默认 MySQL 的引擎为 InnoDB &#xff09; 1.1 数据库的并发场景 数据库并发场景有三种&#xff0c;分别是&#xff1a; 读-读…

深入了解JVM调优:解锁Java应用程序性能的秘诀

文章目录 &#x1f34a; JVM调优&#x1f389; 增大Eden 空间大小&#x1f389; 如果MinorGC 频繁&#xff0c;且容易引发 Full GC&#x1f4dd; S1 区大小 < MGC 存活的对象大小&#xff0c;对象的年龄才1岁&#x1f4dd; 相同年龄的对象所占总空间大小>s1区空间大小的一…

ChatGPT和Copilot协助Vue火速搭建博客网站

AI 对于开发人员的核心价值 网上会看到很多 AI 的应用介绍或者教程 使用 AI 聊天&#xff0c;咨询问题 —— 代替搜索引擎使用 AI 写各种的电商文案&#xff08;淘宝、小红书&#xff09;使用 AI 做一个聊天机器人 —— 这最多算猎奇、业余爱好、或者搞个套壳产品来收费 以上…

2023年中国调速器产量、销量及市场规模分析[图]

调速器行业是指生产、销售和维修各种调速器设备的行业。调速器是一种能够改变机械传动系统输出转速的装置&#xff0c;通过调整输入和输出的转速比来实现转速调节的功能。 调速器行业分类 资料来源&#xff1a;共研产业咨询&#xff08;共研网&#xff09; 随着工业自动化程度…

2023/10/23 mysql学习

数据库修改 show databases; 展示所有数据库 create database 数据库名; 创建数据库 create database if not exists 数据库名; 如果未创建过当前数据库名则创建 drop database 数据库名; drop database if exists 数据库名;用法和创建类似 删除数据库 use 数据库名; 跳…

C++数据结构X篇_20_选择排序(不稳定的排序)

「 选择排序 」虽然在实际应用中没有「 插入排序 」广泛&#xff0c;但它也是我们学习排序算法中必不可少的一种。「 冒泡排序 」和「 插入排序 」都是在两层嵌套循环中慢慢比较元素&#xff0c;不停的调整元素的位置。而「 选择排序 」就比较直接了&#xff0c;属于不出手则已…