当前位置: 首页 > news >正文

springboot配置mysql druid连接池,以及连接池参数解释

文章目录

  • 前置
  • 配置方式
  • 参数解释

前置

  • springboot 项目
  • java
  • mysql
  • druid 连接池

配置方式

在 springboot 的 application.yml 中配置基本方式

# Druid 配置(Spring Boot YAML 格式)
spring:datasource:url: jdbc:mysql://localhost:3306/testdb?useSSL=falseusername: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Driverdruid:initial-size: 5min-idle: 5max-active: 20max-wait: 60000time-between-eviction-runs-millis: 60000validation-query: SELECT 1test-while-idle: truetest-on-borrow: falsetest-on-return: false

参数解释

参数名说明默认值推荐值
连接池配置:
initialSize初始化时创建的物理连接数0如 5
minIdle最小空闲连接;0通常设置为 5~10
maxActive最大活跃连接数(同时可使用的连接数上限)8如 20~100
maxWait获取连接的最大等待时间(毫秒),超时抛出异常。-1 无限等待设置为 5000~60000,避免线程长时间阻塞
连接验证和保活:
validationQuery检测连接是否有效的 SQL(如 SELECT 1)SELECT 1
testWhileIdle空闲时检查连接有效性truetrue
连接回收与驱逐:
timeBetweenEvictionRunsMillis空闲连接检查间隔(毫秒),举例子:如果一个连接在 10:00 被归还到池中,且 timeBetweenEvictionRunsMillis 为 60 秒,则在 10:01 时,该连接的空闲时间已超过阈值,会触发检测60000(1分钟)60000(1分钟)
minEvictableIdleTimeMillis空闲连接的最小存活时间(超过此值可能被驱逐);空闲连接数 > minIdle 且 空闲时间 > 该值,回收多余的空闲连接1800000(30分钟)1800000(30分钟)
maxEvictableIdleTimeMillis空闲连接的最大存活时间(超过此值强制驱逐);空闲时间 > 该值,强制回收所有超时的空闲连接25200000(7小时)25200000(7小时)
性能优化:
poolPreparedStatements是否缓存 PreparedStatementfalse高频查询时设为 true
maxPoolPreparedStatementPerConnectionSize每个连接缓存的 PreparedStatement 数量10自定义设置
性能优化:
removeAbandoned是否回收未归还的连接(如程序异常退出)false,默认 false 是因为其对性能有影响,而且有些业务处理中连接就是很久未归还,默认如果是 true 会带来业务困扰高并发下设置true
removeAbandonedTimeout回收未归还连接的超时时间(秒)300自定

空闲连接:当一个连接使用完毕,并通过相应的归还机制(例如关闭连接对象)返回到连接池中时,它就成为了空闲连接,等待下一次被获取和使用
活跃连接:未归还到连接池的
空闲时:定义空闲时,即上一次连接归还,到下一次连接被请求使用 之间的时间

http://www.xdnf.cn/news/612937.html

相关文章:

  • Python训练营打卡 Day24
  • CloudCanal RAG x Ollama 构建全栈私有 AI 服务
  • 1.2 控制系统的数学模型
  • 深入理解局域网内流量与链路监控的实战价值
  • 连续质数和
  • python web flask专题-Flask入门指南:从安装到核心功能详解
  • 比特授权云外壳加密支持Android 15!
  • DL00912-基于自监督深度聚类的高光谱目标检测含数据集
  • 大模型技术生态全景解析:从基础组件到AGI的演进之路
  • Flink初始及搭建集群环境(技术选型与实战详解)
  • 用AI工具创作出具有史诗感的神话故事短片
  • 制作一款打飞机游戏55:扩散
  • [GHCTF 2025]ret2libc1(NSSCTF)
  • Spring Bean的生命周期
  • 深度学习模型可视化:Netron的安装和使用
  • 深度学习-162-DeepSeek之调用远程大模型API接口参数结构分析
  • Socket 的两个不同含义:硬件 CPU Socket 和 网络 Socket 的区别
  • MySQL——复合查询表的内外连
  • 第十节第七部分:Arrays类、自定义排序规则Comparable、自定义比较器Comparator
  • PHP简介
  • DEEPSEEK + 其他工具的玩法
  • 深入剖析Go并发性能瓶颈:pprof实战指南
  • 力扣面试150题--路径总和
  • Stable Diffusion底模对应的VAE推荐
  • Docker端口映射与容器互联
  • 基于JSP+MySQL 服装销售系统
  • 今日学习:AOP数据脱敏|线程池|方法引用的实例|背包(0-1)及子集
  • 什么是下一代DNS
  • 如何计算VLLM本地部署Qwen3-4B的GPU最小配置应该是多少?多人并发访问本地大模型的GPU配置应该怎么分配?
  • CustomSVG,一键生成SVG,文字秒变矢量图(WIN/MAC)