0

0

mysql Druid连接池怎么用_mysql阿里开源库解析

P粉602998670

P粉602998670

发布时间:2026-01-24 11:19:46

|

130人浏览过

|

来源于php中文网

原创

Druid 是阿里开源的 JDBC 连接池,需配合 mysql-connector-j 驱动使用,通过 DruidDataSource 管理 MySQL 连接;Spring Boot 项目引入 druid-spring-boot-starter 和 mysql-connector-j,配置 url、用户名密码及关键参数如 initialSize、maxPoolSize、testOnBorrow 等,并启用监控页验证连接有效性;MySQL 8.0+ 需用 8.0.28+ 驱动并设置 allowPublicKeyRetrieval=true。

mysql druid连接池怎么用_mysql阿里开源库解析

Druid 连接池怎么配进 MySQL 项目

Druid 是阿里开源的高性能 JDBC 连接池,不是 MySQL 自带组件,也不能直接“用 MySQL 的 Druid”,而是用 DruidDataSource 替代 HikariCPBasicDataSource 来管理 MySQL 数据库连接。核心是:它不改 MySQL 协议,只接管连接的创建、复用、监控和回收。

常见错误是把 druid-spring-boot-starter 当成 MySQL 驱动装,结果启动报 ClassNotFoundException: com.mysql.cj.jdbc.Driver——Druid 不提供驱动,mysql-connector-java(或新版 mysql-connector-j)必须单独引入。

  • Spring Boot 项目需同时声明 mysql-connector-jdruid-spring-boot-starter
  • 非 Spring 项目则直接 new DruidDataSource(),手动 set urlusernamepassworddriverClassName
  • url 必须是标准 MySQL JDBC 格式,例如:jdbc:mysql://127.0.0.1:3306/test?useSSL=false&serverTimezone=UTC

关键参数怎么设才不翻车

Druid 默认配置偏保守,直连生产 MySQL 容易出现连接超时、空闲释放过早、SQL 执行慢无感知等问题。几个高频出错的参数:

  • initialSize:默认 0,应用刚启动时没预热连接,首请求可能卡住;建议设为 2–5
  • minIdlemaxActive(新版叫 maxOpenPreparedStatements 已废弃,实际控制并发连接数的是 maxPoolSize):若 minIdle 太低(如 0),连接空闲 60 秒后被回收,下次来又要重建;若 maxPoolSize 小于业务峰值并发,会排队等连接,表现像数据库慢
  • testOnBorrow:默认 false,从池里取连接时不检测有效性,遇到 MySQL 主从切换或网络闪断,可能拿到失效连接;建议设 true + 配合 validationQuery=SELECT 1
  • phyTimeoutMillis:物理连接最大存活时间,避免长连接被 MySQL 的 wait_timeout 中断导致异常;建议设略小于 MySQL 的 wait_timeout 值(如 MySQL 设 28800,这里设 28000)

怎么查 Druid 是否真在用、连的是哪个 MySQL 实例

光看启动日志不够,得验证运行时行为。Druid 内置监控页(默认 /druid)是最直接方式,但需显式开启:

spring:
  datasource:
    druid:
      web-stat-filter:
        enabled: true
      stat-view-servlet:
        enabled: true
        url-pattern: /druid/*
        login-username: admin
        login-password: admin

访问 http://localhost:8080/druid 后,在「数据源」页能看到当前连接的 url、活跃连接数、SQL 执行统计;点「SQL 监控」可查慢 SQL 和执行堆。注意:该页面暴露敏感信息,生产务必关掉或加 IP 白名单。

IBM Watson
IBM Watson

IBM Watson文字转语音

下载

另一个验证点是日志——开启 com.alibaba.druid.pool.DruidDataSource 的 DEBUG 日志,能看见类似 create connection, url: jdbc:mysql://10.0.1.5:3306/mydb 的输出,确认连的是目标实例而非本地测试库。

MySQL 8.0+ 和 Druid 兼容要注意啥

MySQL 8.0 默认启用 caching_sha2_password 插件,而老版本 Druid(1.1.10 之前)依赖的 mysql-connector-java 5.x 不支持该认证方式,会报 Unknown initial character set index '255' received from serverPublic Key Retrieval is not allowed

  • 必须升级 mysql-connector-j 到 8.0.28+(推荐 8.0.33)
  • URL 中显式指定 serverTimezoneallowPublicKeyRetrieval=true,例如:jdbc:mysql://localhost:3306/test?serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useSSL=false
  • Druid 本身无需升级,但若用 druid-spring-boot-starter,建议 >= 1.2.18,它对新驱动适配更稳

另外,MySQL 8.0 的 information_schema.PROCESSLIST 显示的连接用户是 Druid 配置的 username,不是操作系统用户——这点排查权限问题时容易误判。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

844

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

743

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

740

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

400

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

447

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 807人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号