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

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

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.mzph.cn/news/118590.shtml

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

相关文章

国密 SM2 SSL 证书 Nginx 安装指南 linux版

一、获取国密证书 1、在您完成申请西部GDCA服务器证书的流程后&#xff0c;下载证书将获取一个证书包&#xff0c;有以下 *.***.com_sign.crt&#xff1a;签名证书 *.***.com_sign.key&#xff1a;签名证书私钥 *.***.com_encrypt.crt&#xff1a;加密证书 *.***.com_encr…

【C++笔记】如何用检查TCP或UDP端口是否被占用

一、检查步骤 使用socket函数创建socket_fd套接字。使用sockaddr_in结构体配置协议和端口号。使用bind函数尝试与端口进行绑定&#xff0c;成功返回0表示未被占用&#xff0c;失败返回-1表示已被占用。 二、步骤详解 2.1 socket函数 socket 函数是用于创建套接字的函数&…

linuxnfs服务安装与配置实践

目录 一.NFS服务 二.NFS和RPC的概念 三.什么是RPC 四.工具 五.安装配置NFS环境 1.查看一下是否有nfs-utils和rpcbind软件包的安装rpm包 2.安装nfs-utils 、rpcbind 3.环境配置 1.nfs配置文件需要遵守如下规则&#xff1a; 2.nfs语法参数解释&#xff1a; 3.nfs客户端…

质数(素数)prime :只能被 1 和 它本身整除的自然数,不可再分,(三种方式求出质数)

从 2 开始&#xff0c;到这个数 减 1 结束为止&#xff0c; 都不能被这个数本身整除。例如&#xff1a;5 是否是质数 &#xff1f; 那么 2&#xff0c;3&#xff0c;4&#xff0c;都不能被 5 整除 所以 5 是 质数判断 n 是否是质数&#xff1f; 2&#xff0c;3&#xff0c;4&…

el-tree横向纵向滚动条

el-tree未展开时样式 el-tree展开时样式 给容器一个高度&#xff0c;然后样式加上overflow: scroll&#xff0c;这样纵向滚动条就出来了。 <el-card style"height: 528px;overflow: scroll"><el-inputplaceholder"输入关键字进行过滤"v-model&…

嵌入式系统设计师考试笔记之操作系统基础复习笔记一

目录 1、嵌入式软件基础 &#xff08;1&#xff09;嵌入式软件的特点&#xff1a; &#xff08;2&#xff09;嵌入式软件分类&#xff1a; &#xff08;3&#xff09;无操作系统的嵌入式软件的两种实现方式&#xff1a; &#xff08;4&#xff09;有操作系统的三大优点&am…

2021-arXiv-The Power of Scale for Parameter-Efficient Prompt Tuning

2021-arXiv-The Power of Scale for Parameter-Efficient Prompt Tuning Paper: https://arxiv.org/abs/2104.08691 Code: https://github.com/google-research/ text-to-text-transfer-transformer/ blob/main/released_checkpoints.md# lm-adapted-t511lm100k 在这项工作中&…

大数据调度最佳实践 | 从Airflow迁移到Apache DolphinScheduler

迁移背景 有部分用户原来是使用 Airflow 作为调度系统的&#xff0c;但是由于 Airflow 只能通过代码来定义工作流&#xff0c;并且没有对资源、项目的粒度划分&#xff0c;导致在部分需要较强权限控制的场景下不能很好的贴合客户需求&#xff0c;所以部分用户需要将调度系统从…

地面文物古迹保护方案,用科技为文物古迹撑起“智慧伞”

一、行业背景 当前&#xff0c;文物保护单位的安防系统现状存在各种管理弊端&#xff0c;安防系统没有统一的平台&#xff0c;系统功能不足、建设标准不同&#xff0c;产品和技术多样&#xff0c;导致各系统独立&#xff0c;无法联动&#xff0c;形成了“信息孤岛”。地面文物…

阿里云服务结构--长期更新

CNCF 全称Cloud Native Computing Foundation&#xff08;云原生计算基金会&#xff09;&#xff0c;成立于 2015 年7月21日&#xff08;于美国波特兰OSCON 2015上宣布&#xff09;&#xff0c;其最初的口号是坚持和整合开源技术来让编排容器作为微服务架构的一部分&#xff0…

uni-app中tab选项卡的实现效果 @click=“clickTab(‘sell‘)“事件可传参数

一、效果图 二、代码 <template><view><view class"choose-tab"><view class"choose-tab-item" :class"chooseTab 0 ? active : " data-choose"0" click"clickTab">选项1</view><view …

JVM | 命令行诊断与调优 jhsdb jmap jstat jps

目录 jmap 查看堆使用情况 查看类列表&#xff0c;包含实例数、占用内存大小 生成jvm的堆转储快照dump文件 jstat 查看gc的信息&#xff0c;查看gc的次数&#xff0c;及时间 查看VM内存中三代&#xff08;young/old/perm&#xff09;对象的使用和占用大小 查看元数据空…

Spark【Spark Streaming】

1、基本数据源 1.1、文件流 在spark Shell 下运行&#xff1a; [lyhhadoop102 spark-yarn-3.2.4]$ spark-shell Setting default log level to "WARN". To adjust logging level use sc.setLogLevel(newLevel). For SparkR, use setLogLevel(newLevel). 2022-09-…

HTML笔记-狂神

1. 初识HTML 什么是HTML&#xff1f; Hyper Text Markup Language : 超文本标记语言 超文本包括&#xff1a;文字、图片、音频、视频、动画等 目前使用的是HTML5&#xff0c;使用 W3C标准 W3C标准包括&#xff1a; 结构化标准语言&#xff08;HTML、XML&#xff09; 表现标…

Kafak - 单机/集群快速安装指北(3.x版本)

文章目录 官方下载地址上传安装包解压安装包到指定目录修改解压包名为kafka修改config目录下的配置文件server.propertie配置环境变量其他机器同上 - 修改配置文件中的brokerid启动集群停止Kraft 方式部署集群----(不使用zookeeper) 官方下载地址 http://kafka.apache.org/dow…

【ROS入门】机器人系统仿真——相关组件以及URDF集成Rviz

文章结构 相关组件URDF(Unified Robot Description Format)——创建机器人模型Gazebo——搭建仿真环境Rviz(ROS Visualization Tool)——显示机器人各种传感器感知到的环境信息 URDF集成RvizURDF相关语法robotlinkjoint URDF优化——xacro相关语法属性与算数运算宏文件包含 实操…

工作:三菱伺服驱动器连接参数及其电机钢性参数配置与调整

工作&#xff1a;三菱伺服驱动器参数及电机钢性参数配置与调整 一、三菱PLC与伺服驱动器连接参数的设置 1. 伺服配置 单个JET伺服从站链接侧占用点数:Rx/Ry占用64点、RWw/RWr占用32点 图中配置了22个JET伺服从站&#xff0c;占用点数:Rx/Ry占用64222048‬点、RWw/RWr占用322…

基于YOLOv8模型和UA-DETRAC数据集的车辆目标检测系统(PyTorch+Pyside6+YOLOv8模型)

摘要&#xff1a;基于YOLOv8模型和UA-DETRAC数据集的车辆目标检测系统可用于日常生活中检测与定位汽车&#xff08;car&#xff09;、公共汽车&#xff08;bus&#xff09;、面包车&#xff08;vans&#xff09;等目标&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方…

金融行业网络安全保护与三级等保合规实施方案

金融行业网络安全保护与三级等保合规实施方案旨在帮助金融机构实施符合三级等保标准的网络安全保护措施。以下是一个基本的实施方案概述&#xff1a; 评估和规划&#xff1a; 进行风险评估&#xff1a;评估网络系统的风险&#xff0c;确定安全威胁、弱点和潜在风险。 确定等级…

Node学习笔记之MongoDB

一、简介 1.1 Mongodb 是什么 MongoDB 是一个基于分布式文件存储的数据库&#xff0c;官方地址 MongoDB: The Developer Data Platform | MongoDB 1.2 为什么选择 Mongodb 操作语法与 JavaScript 类似&#xff0c;容易上手&#xff0c;学习成本低 二、核心概念 Mongodb 中…