文章目录

  • 一、前言
  • 二、什么是数据库连接池?
  • 三、SpringBoot + KingbaseES 环境准备
    • 3.1 加依赖(pom.xml)
    • 3.2 基础连接信息(application.yml)
  • 四、四类主流连接池实战
    • 4.1 DBCP(迁移型 / 传统项目友好)
      • SpringBoot配置方式
      • application.yml配置
      • 实际应用示例
    • 4.2 C3P0
      • SpringBoot配置方式
    • 4.3 Druid(生产推荐 + 可视化)
      • application.yml配置
      • SpringBoot配置方式
    • 4.4 HikariCP(SpringBoot默认 / 高性能首选)
      • application.yml配置
      • SpringBoot配置方式
  • 五、总结

一、前言

在做企业级项目时,我们常常一边催进度、一边盯性能:页面得快、接口得稳,背后最“默默无闻”却又至关重要的那部分,往往就是数据库连接管理。要是真到高峰期才现开连接,应用就像高铁只剩一条候车通道 —— 堵,全线慢。于是,连接池这种“提前把通道铺好、闸机开好”的机制,就成了性能优化的基本盘。

在国产数据库里,KingbaseES这几年在医疗,交通等对可靠性、合规性要求极高的场景里越用越多。很多团队在把原本的Oracle、PostgreSQL体系平滑迁移到KingbaseES之后,会立刻面临一个现实问题:到底选哪个连接池?DBCP老牌稳健,C3P0历史悠久但偏重,Druid监控维度丰富又接地气,HikariCP主打“极致轻快”。本文就结合Spring Boot的真实开发场景,把这四种主流方案的配置思路、适用特征与优化要点一次讲清,帮你少走弯路。

二、什么是数据库连接池?

简单说,数据库连接池就是在程序真正“要水”之前,先把水桶排好、龙头拧开,等你来接;而不是每次渴了再去打一趟井水。创建和关闭数据库连接本身是昂贵的系统操作:握手、认证、分配资源,步骤一个不能少。如果每个HTTP请求都临时建连、用完就销毁,系统资源就会被这些重复动作消耗掉,吞吐量和响应时间都会被拖慢。连接池的做法是:启动或空闲阶段先准备一批可用连接(最小池);高峰期可按规则扩容(最大池);请求来时“借”一条,用完“还”回去;若有“坏桶”(失效连接),再做检测和重建。结果是:响应更稳定、抖动更小,还能通过统计与监控为后续容量评估提供数据支撑。

三、SpringBoot + KingbaseES 环境准备

三步心智模型:

  1. 加依赖(让项目知道怎么连库)
  2. 填地址(告诉它去哪里、用谁登录)
  3. 验连通(启动时或写个最小 SQL 探活)

3.1 加依赖(pom.xml)

最少必备 = JDBC + 驱动 + 选一个连接池(别全塞上,冲突或白占空间)。

<dependencies><!-- Spring JDBC 基础 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><!-- KingbaseES 驱动(版本锁定,跟服务器一致) --><dependency><groupId>com.kingbase8</groupId><artifactId>kingbase8</artifactId><version>8.6.0</version></dependency><!-- 连接池:三选一(推荐 Hikari 或 Druid) --><!-- Druid(生产监控友好) --><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.18</version></dependency><!-- 或 Apache DBCP2(老系统迁移) --><dependency><groupId>org.apache.commons</groupId><artifactId>commons-dbcp2</artifactId></dependency><!-- 或 HikariCP(高性能 / Spring Boot 默认) --><dependency><groupId>com.zaxxer</groupId><artifactId>HikariCP</artifactId></dependency>
</dependencies>

提示: 如果用 Spring Boot Starter,很多情况下不必单独引 HikariCP,它已内嵌。

3.2 基础连接信息(application.yml)

一定核对四件套:地址 / 端口 / 库名 / 账号密码 + 驱动类名。

kingbase:driver-class-name: com.kingbase8.Driverurl: jdbc:kingbase8://127.0.0.1:54321/TESTusername: SYSTEMpassword: SYSTEM

小建议:
生产别写死密码 → 用环境变量或外部化配置(如:ENC、K8S Secret)
若多数据源,分前缀管理,别混在 spring.datasource 根层

四、四类主流连接池实战

DBCP: 老黄牛,稳但不花哨。
C3P0: 功能多,参数细,适合“历史复杂场景”兜底。
Druid: 自带监控 + SQL 防火墙,运维爱。
HikariCP: 快、轻、现代、高并发友好。

4.1 DBCP(迁移型 / 传统项目友好)

看点:initial-size / max-total / validation-query 三核心。

SpringBoot配置方式

@Configuration
public class DbcpDataSourceConfig {@Bean@Primary@ConfigurationProperties(prefix = "spring.datasource.dbcp")public DataSource dbcpDataSource() {return new BasicDataSource();}
}

application.yml配置

spring:datasource:dbcp:driver-class-name: com.kingbase8.Driverurl: jdbc:kingbase8://127.0.0.1:54321/TESTusername: SYSTEMpassword: MANAGERinitial-size: 5max-total: 50min-idle: 5max-idle: 20validation-query: SELECT 'x'test-on-borrow: truetest-while-idle: truetime-between-eviction-runs-millis: 60000min-evictable-idle-time-millis: 1800000

实际应用示例

@Service
public class UserService {@Autowiredprivate JdbcTemplate jdbcTemplate;public List<User> findAllUsers() {return jdbcTemplate.query("SELECT id, name, email FROM users",(rs, i) -> {User u = new User();u.setId(rs.getLong("id"));u.setName(rs.getString("name"));u.setEmail(rs.getString("email"));return u;});}
}

4.2 C3P0

核心参数:
acquireIncrement:不够时一次加多少
idleConnectionTestPeriod:健康巡检周期(秒)
preferredTestQuery:轻量探活

SpringBoot配置方式

@Bean
public DataSource c3p0DataSource() throws PropertyVetoException {ComboPooledDataSource ds = new ComboPooledDataSource();ds.setDriverClass("com.kingbase8.Driver");ds.setJdbcUrl("jdbc:kingbase8://127.0.0.1:54321/TEST");ds.setUser("SYSTEM");ds.setPassword("SYSTEM");ds.setInitialPoolSize(5);ds.setMinPoolSize(5);ds.setMaxPoolSize(50);ds.setAcquireIncrement(3);ds.setIdleConnectionTestPeriod(10);ds.setPreferredTestQuery("SELECT 1");ds.setMaxIdleTime(1800);return ds;
}

注意: 巡检太频繁(如 <5s)会浪费资源;查询语句尽量轻。

4.3 Druid(生产推荐 + 可视化)

优点:SQL 监控、慢 SQL、Wall 防注入、Web 控制台一站式。

application.yml配置

spring:datasource:druid:driver-class-name: com.kingbase8.Driverurl: jdbc:kingbase8://127.0.0.1:54321/TESTusername: SYSTEMpassword: MANAGERinitial-size: 5max-active: 50min-idle: 5max-wait: 60000time-between-eviction-runs-millis: 60000min-evictable-idle-time-millis: 1800000validation-query: SELECT 'x'test-while-idle: truetest-on-borrow: falsetest-on-return: falsefilters: stat,wall,log4j2web-stat-filter:enabled: trueurl-pattern: /*exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*"stat-view-servlet:enabled: trueurl-pattern: /druid/*reset-enable: falselogin-username: adminlogin-password: admin123

SpringBoot配置方式

@Configuration
public class DruidConfig {@Bean@ConfigurationProperties("spring.datasource.druid")public DataSource druidDataSource() {return new DruidDataSource();}@Beanpublic ServletRegistrationBean<StatViewServlet> druidStatViewServlet() {ServletRegistrationBean<StatViewServlet> bean =new ServletRegistrationBean<>(new StatViewServlet(), "/druid/*");bean.addInitParameter("loginUsername", "admin");bean.addInitParameter("loginPassword", "admin123");bean.addInitParameter("resetEnable", "false");return bean;}
}

控制台路径:/druid/index.html
账号密码务必生产自定义 + 限制 IP

4.4 HikariCP(SpringBoot默认 / 高性能首选)

特点:启动快、延迟低、参数少、容错好。

application.yml配置

spring:datasource:hikari:driver-class-name: com.kingbase8.Driverjdbc-url: jdbc:kingbase8://127.0.0.1:54321/TESTusername: SYSTEMpassword: SYSTEMminimum-idle: 5maximum-pool-size: 50connection-timeout: 10000idle-timeout: 600000max-lifetime: 1800000validation-timeout: 5000connection-test-query: SELECT 1pool-name: KingbaseHikariCPauto-commit: trueleak-detection-threshold: 60000

SpringBoot配置方式

@Configuration
public class HikariTunedConfig {@Bean@Primary@ConfigurationProperties(prefix = "spring.datasource.hikari")public HikariDataSource hikariDataSource() {HikariDataSource ds = new HikariDataSource();ds.addDataSourceProperty("cachePrepStmts", "true");ds.addDataSourceProperty("prepStmtCacheSize", "250");ds.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");ds.addDataSourceProperty("useServerPrepStmts", "true");return ds;}
}

五、总结

如果把数据库访问想成办公室喝水:别每次口渴才跑去打井(临时建连接),而是先备好一排干净水杯(连接池)。

在 Spring Boot + KingbaseES 里,HikariCP 就像那台又快又省心的新式饮水机,默认首选;

Druid 像带大屏的智能款,能看水量、过滤杂质(监控与防护),适合需要可视化和审计的团队;

DBCP、C3P0 则更像老设备,除非历史原因暂时换不动,否则不用再投入。

真正的优化不是把“杯子”堆得越多越好,而是先弄清高峰时有多少人会来、每个人平均用多久,然后设一个刚好撑得住又不浪费的位置,再盯慢查询和长事务,及时清理“卡着不放的杯子”。一句话:先选对(优先 Hikari,需监控加 Druid),再测清楚,再精调,持续看指标,系统就会既稳又顺。

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

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

相关文章

矩阵待办ios app Tech Support

Getting Support: mail: 863299715qq.com

React中优雅管理CSS变量的最佳实践

在现代前端开发中&#xff0c;CSS变量&#xff08;也称为CSS自定义属性&#xff09;已成为管理样式系统的重要工具。它们提供了强大的动态样式能力&#xff0c;但在JavaScript中高效地访问和使用这些变量却存在一些挑战。本文将介绍一个优化的解决方案&#xff0c;帮助你在Reac…

智能制造——解读装备制造业智能工厂解决方案【附全文阅读】

适应人群为装备制造企业(如汽车、航空航天、能源装备等)中高层管理者、生产运营负责人、IT 部门(智能制造 / 工业互联网团队)、安全管理专员及园区数字化建设决策者。主要内容围绕装备制造业智能工厂解决方案展开,核心包括建设背景(解决生产安全管理缺失、工序手工记录无…

macos调用chrome后台下载wasm-binaries.tar.xz

实现脚本: down_wasm.sh DOWNLOAD_DIR="$HOME/Downloads" TARGET_FILE="wasm-binaries.tar.xz" TAG="32b8ae819674cb42b8ac2191afeb9571e33ad5e2" TARGET_DIR="$HOME/Desktop/sh/emsdk_setup/emsdk_deps"echo "下载路径: $DOW…

【Proteus仿真】按键控制系列仿真——LED灯表示按键状态/按键控制LED灯/4*4矩阵键盘控制LED

目录 1案例视频效果展示 1.1例子1&#xff1a;LED灯表示按键状态(两种方式) 1.2例子2&#xff1a;按键控制两排LED小灯闪烁移位 1.3例子3&#xff1a;按键控制LED灯逐个点亮/分组点亮/全部熄灭 1.4例子4&#xff1a;4*4矩阵按键实现带状LED灯控制 2例子1&#xff1a;LED灯…

829作业

用fgets&#xff0c;fputswanc代码#include<myhead.h> int main(int argc, const char *argv[]) {FILE *fp1 NULL;FILE *fp2 NULL;if (argc ! 3){printf("输入不合法:./a.out lydf.txt l.txt\n");return -1;}if ((fp1fopen(argv[1],"w"))NULL){pri…

CRMEB小程序订阅消息配置完整教程(PHP版)附常见错误解决

登录小程序后台 1.进入微信公众平台、小程序后台&#xff1a;功能->订阅消息。&#xff08;如未开通&#xff0c;点击申请即可开通&#xff09; 选择服务类目 2.选择服务类目&#xff1a;生活服务/百货/超市/便利店 同步小程序订阅消息 3.商城后台设置->消息管理 点击…

【已解决】阿里云服务器上前端访问不到后端

最开始我觉得后端根本没跑起来&#xff0c;但是我没用过阿里云的服务器&#xff0c;对pm2指令也完全不熟&#xff0c;不确定后端是不是在哪个我不知道的地方跑着。 还以为在阿里云控制台点运行&#xff0c;服务就会自己跑起来&#xff0c;但远程连接之后发现搞着搞着&#xff0…

分治算法详解:从递归思想到经典应用实战

分治算法是计算机科学中最重要的算法设计策略之一&#xff0c;它将复杂问题分解为规模更小的同类子问题&#xff0c;通过递归求解子问题并合并结果来解决原问题。本文将深入探讨分治算法的核心思想、设计模式以及经典应用案例。 文章目录一、分治算法核心思想1.1 分治策略的三个…

GitHub 热榜项目 - 日榜(2025-08-31)

GitHub 热榜项目 - 日榜(2025-08-31) 生成于&#xff1a;2025-08-31 统计摘要 共发现热门项目&#xff1a;15 个 榜单类型&#xff1a;日榜 本期热点趋势总结 本期GitHub热榜凸显三大技术热点&#xff1a;1) AI基础设施爆发式增长&#xff0c;微软MCP协议和Activepieces的A…

OpenCL C 平台与设备

1. 核心概念在 OpenCL C API 中&#xff1a;平台 (Platform)&#xff1a;代表一个 OpenCL 实现&#xff0c;通常对应硬件厂商&#xff08;NVIDIA、AMD、Intel等&#xff09;设备 (Device)&#xff1a;具体的计算硬件单元&#xff08;GPU、CPU、加速器等&#xff09;上下文 (Con…

R语言贝叶斯方法在生态环境领域中的高阶技术应用

贝叶斯统计已经被广泛应用到物理学、生态学、心理学、计算机、哲学等各个学术领域&#xff0c;其火爆程度已经跨越了学术圈。一&#xff1a; 1.1复杂数据回归&#xff08;混合效应&#xff09;模型的选择策略 1&#xff09;科学研究中数据及其复杂性 2&#xff09;回归分析历史…

学习笔记:MySQL(day1)

DDL&#xff08;Data Definition Language&#xff0c;数据定义语言&#xff09;是 SQL 语言的一部分&#xff0c;用于定义和管理数据库中的数据结构&#xff0c;包括创建、修改、删除数据库对象&#xff08;如数据库、表、视图、索引等&#xff09;。常见的 DDL 语句及其功能&…

C++ 模板初阶:从函数重载到泛型编程的优雅过渡

&#x1f525;个人主页&#xff1a;爱和冰阔乐 &#x1f4da;专栏传送门&#xff1a;《数据结构与算法》 、C &#x1f436;学习方向&#xff1a;C方向学习爱好者 ⭐人生格言&#xff1a;得知坦然 &#xff0c;失之淡然 文章目录前言一、引言&#xff1a;函数重载的痛点与模板…

从零开始的python学习——语句

ʕ • ᴥ • ʔ づ♡ど &#x1f389; 欢迎点赞支持&#x1f389; 个人主页&#xff1a;励志不掉头发的内向程序员&#xff1b; 专栏主页&#xff1a;python学习专栏&#xff1b; 文章目录 前言 一、顺序语句 二、条件语句 2.1、什么是条件语句 2.2、语法格式 2.3、缩进和代码…

Python基础之元组列表集合字典

目录一、元组&#xff08;Turple&#xff09;1.1、概念定义注意事项1.2、常见操作元组只支持查询操作&#xff0c;不支持增删改操作。查询元素二、列表1.1、概念定义注意事项1.2、常见操作添加修改查找删除排序列表推导式列表嵌套三、集合1.1、概念定义集合的特点1.2、常见操作…

Ubuntu 22.04 安装 向日葵远程Client端

通过向日葵主页的下载deb包有可能遇到安装失败的情况 #因向向日葵提供的libwebkit包是4.0-37了,而向日葵依赖的是3.0.0(Reading database ... 303666 files and directories currently installed.) Preparing to unpack SunloginClient-10.1.1.38139_amd64.deb.1 ... sunloginc…

Linux中卸载和安装Nginx

阿里云宝塔linux为例一&#xff1a;卸载1.停止 Nginx 服务# 检查Nginx运行状态 systemctl status nginx# 停止Nginx服务 sudo systemctl stop nginx# 禁用开机自启 sudo systemctl disable nginx2. 卸载 Nginx 软件包# 查看已安装的Nginx包 yum list installed | grep nginx# 卸…

C++知识汇总(5)

目录 1.写在前面 1.C11的发展历史 2.序列表初始化 3&#xff0c;C11中的std::initializer_list 4.左值和右值 1.左值引用和右值引用 2.生命周期的延长 3.左值和右值的参数匹配 4&#xff0c;移动构造和移动赋值 5.引用折叠 6.完美转发 总结 1.可变模板参数 2.包扩展…

LeetCode 每日一题 2025/8/25-2025/8/31

记录了初步解题思路 以及本地实现代码&#xff1b;并不一定为最优 也希望大家能一起探讨 一起进步 目录8/25 498. 对角线遍历8/26 3000. 对角线最长的矩形的面积8/27 3459. 最长 V 形对角线段的长度8/28 3446. 按对角线进行矩阵排序8/29 3021. Alice 和 Bob 玩鲜花游戏8/30 36.…