提升性能:数据库与 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 开启批量插入 / 更新优化,提升写性能
相关推荐
百结2143 小时前
Mysql数据库操作
数据库·mysql·oracle
keep one's resolveY4 小时前
时区问题解决
数据库
Leinwin4 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
qq_417695054 小时前
机器学习与人工智能
jvm·数据库·python
漫随流水4 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
ego.iblacat4 小时前
MySQL 服务基础
数据库·mysql
Maverick066 小时前
Oracle Redo 日志操作手册
数据库·oracle
攒了一袋星辰6 小时前
高并发强一致性顺序号生成系统 -- SequenceGenerator
java·数据库·mysql
W.D.小糊涂6 小时前
gpu服务器安装windows+ubuntu24.04双系统
c语言·开发语言·数据库
云贝教育-郑老师6 小时前
【OceanBase 的多租户架构是怎样的?有什么优势?】
数据库·oceanbase