JDBC进阶之连接池的配置(Druid与HikariCP)

在我们前面的JDBC与数据库的连接中,每次操作都要用connection对象重新获取连接,用完之后再释放,但频繁的创建和销毁会造成资源的浪费,并且只连接一个对象。那么实际应用中,对于服务器来说压力非常大,于是我们用连接池来进行连接。

今天我们就来用两款比较常用的连接池,Druid与HikariCP。

特性 HikariCP Druid (阿里巴巴)
核心定位 极致性能的纯连接池 功能全面的数据库连接池与监控平台
性能 业界标杆,极致快 性能优秀,但与HikariCP在极限场景下有微小差距
功能特性 专注、核心:连接池生命周期管理、合理的默认配置 全面、强大 :连接池、SQL监控、防火墙、SQL解析、慢查询日志、Spring集成
监控与运维 基础:通过JMX暴露少量指标,需自行集成监控系统 强大、开箱即用 :提供内置的监控页面,详细的统计信息(SQL执行次数、时间、慢SQL、连接池状态等)
易用性 非常简单:配置少,依赖小,"默认即合理" 相对复杂:功能多,配置项也多,需要一定学习成本
社区与生态 非常活跃,是 Spring Boot 2.x 及以上的默认连接池 非常活跃,阿里巴巴开源,在国内有广泛应用和丰富的文档
轻量级 非常轻量,代码精炼,Jar包小 相对较重,因为集成了大量功能
适用场景 微服务、云原生、高性能Web应用,追求极致性能和简洁 企业级应用、需要详细监控和SQL分析的场景,对运维监控要求高

1.Druid示例

下载druid的jar包

官网下载路径如下:

Central Repository: com/alibaba/druid

1.硬编码

复制代码
硬编码:将连接池的配置信息与JAVA代码耦合在一起但不利于维护。

2.软编码

在项目目录下创建resource文件夹,创建db.properties配置文件,将连接信息定义在该文件中。

2.Hikari示例

这里需要两个包:Hikari jar 包和slf4 jar包(日志文件)

HikariCP官网下载路径如下:

Central Repository: org/slf4j/slf4j-api

Central Repository: com/zaxxer/HikariCP

1.硬编码

2.软编码

编写配置文件。

相关推荐
寻寻觅觅☆11 分钟前
东华OJ-基础题-104-A == B ?(C++)
开发语言·c++
马猴烧酒.12 分钟前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
lightqjx21 分钟前
【C++】unordered系列的封装
开发语言·c++·stl·unordered系列
天天爱吃肉821836 分钟前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
zh_xuan36 分钟前
kotlin lazy委托异常时执行流程
开发语言·kotlin
大巨头1 小时前
sql2008 数据库分页语句
数据库
sino爱学习1 小时前
高性能线程池实践:Dubbo EagerThreadPool 设计与应用
java·后端
m0_715575341 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
阿猿收手吧!1 小时前
【C++】string_view:高效字符串处理指南
开发语言·c++
老邓计算机毕设1 小时前
SSM智慧社区家政服务系统80q7o(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架