提升性能:数据库与 Druid 连接池优化指南

上云优惠聚集地,云小站专属折扣优惠。https://www.aliyun.com/minisite/goods?userCode=7yp9j8y0🚀 提升性能:数据库与 Druid 连接池优化指南

结合,服务器内存处理器小导致查询慢或数据量大查询慢,容易被锁等场景,我帮你梳理一下MySQL 配置Druid 连接池配置的关键优化点,直接上可落地的配置方案。


🔧 一、MySQL 数据库配置优化

这些配置修改需要在 my.cnfmy.ini 文件中调整,然后重启 MySQL 生效。

ini

bash 复制代码
# 1. 连接与超时优化(减少Sleep连接堆积)
wait_timeout = 60          # 空闲连接超时时间(秒),默认8小时,建议设为60-300
interactive_timeout = 60   # 与wait_timeout保持一致
max_connections = 200      # 最大连接数,根据服务器CPU核数调整(建议CPU核数*2 + 有效磁盘数)

# 2. 查询性能优化
query_cache_type = 0       # 关闭查询缓存(MySQL 8.0已移除,5.7建议关闭)
tmp_table_size = 64M       # 临时表大小,避免磁盘临时表
max_heap_table_size = 64M  # 内存临时表上限
sort_buffer_size = 2M      # 排序缓冲区,每个连接分配,建议2-4M
join_buffer_size = 2M      # 连接缓冲区,每个连接分配,建议2-4M

# 3. 索引与IO优化
innodb_buffer_pool_size = 4G  # 缓冲池大小,建议设为服务器内存的50%-70%(例如8G内存设为4G)
innodb_log_file_size = 1G     # 重做日志大小,建议1-2G,减少刷盘频率
innodb_flush_log_at_trx_commit = 2  # 每秒刷盘一次,平衡性能与安全性

🛠️ 二、Spring Boot Druid 连接池优化

application.yml 中调整以下参数,让连接池更适配你的业务场景:

yaml

复制代码
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driverClassName: com.mysql.cj.jdbc.Driver
    druid:
      # 1. 基础连接配置
      url: jdbc:mysql://localhost:3306/your_db?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&rewriteBatchedStatements=true
      username: root
      password: your_password

      # 2. 连接池核心大小(关键)
      initial-size: 5               # 初始化连接数
      min-idle: 5                   # 最小空闲连接数,建议与initial-size一致
      max-active: 20                # 最大活跃连接数,建议不超过MySQL的max_connections
      max-wait: 60000               # 获取连接的最大等待时间(毫秒)

      # 3. 连接回收与超时(关键)
      time-between-eviction-runs-millis: 60000  # 检测空闲连接的间隔时间
      min-evictable-idle-time-millis: 300000    # 连接最小空闲时间(5分钟),超过则回收
      test-while-idle: true                     # 空闲时检测连接有效性
      test-on-borrow: false                     # 获取连接时不检测(提升性能)
      test-on-return: false                     # 归还连接时不检测(提升性能)

      # 4. 连接保活(防止被MySQL主动断开)
      keep-alive: true
      phy-use-connection-test-timeout: 60000    # 物理连接检测超时时间

      # 5. 监控与统计(可选)
      filters: stat,wall,slf4j
      web-stat-filter:
        enabled: true
      stat-view-servlet:
        enabled: true
        login-username: admin
        login-password: admin

🎯 三、核心优化逻辑说明

  1. 减少 Sleep 连接堆积

    • MySQL 端:wait_timeout=60 让数据库主动关闭空闲连接;
    • Druid 端:min-evictable-idle-time-millis=300000 让连接池主动回收空闲超过 5 分钟的连接,避免连接泄漏。
  2. 提升连接复用效率

    • max-active 设为 20,避免连接数过多导致 MySQL 上下文切换开销;
    • test-on-borrow=false 减少连接检测的性能损耗,依赖 test-while-idle 保证连接有效性。
  3. 适配 MySQL 8.0 + 驱动

    • URL 中添加 allowPublicKeyRetrieval=true 避免驱动连接报错;
    • rewriteBatchedStatements=true 开启批量插入 / 更新优化,提升写性能
相关推荐
砚边数影2 小时前
AI数学基础(一):线性代数核心,向量/矩阵运算的Java实现
java·数据库·人工智能·线性代数·矩阵·ai编程·金仓数据库
虹科网络安全2 小时前
艾体宝新闻 | Redis 月度更新速览:2025 年 12 月
数据库·redis·缓存
Linux-palpitate2 小时前
PostgreSQL单机部署
数据库·postgresql
engchina2 小时前
自然语言转 SQL 并不是“魔法”
数据库·人工智能·sql·text2sql·nl2sql·自然语言转sql
小陈phd3 小时前
langGraph从入门到精通(六)——基于 LangGraph 实现结构化输出与智能 Router 路由代理
android·网络·数据库
安当加密3 小时前
电力系统如何防“明文传输”?某电网公司用SM2+UKey构建“端到端加密”实战
服务器·数据库·安全·阿里云
Maggie_ssss_supp3 小时前
Linux-MySQL权限管理
linux·运维·mysql
BD_Marathon3 小时前
动态SQL(六)foreach标签2
数据库·sql
小豪GO!3 小时前
数据库-八股
数据库