提升性能:数据库与 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 开启批量插入 / 更新优化,提升写性能
相关推荐
脑子进水养啥鱼?16 分钟前
PostgreSQL .history 文件
数据库·postgresql
倔强的石头_30 分钟前
5 个真实案例带你避坑:DolphinDB 实时写入、流订阅与高可用调优
数据库
虹科网络安全36 分钟前
艾体宝新闻|Redis 月度更新速览:2026 年 3 月
数据库·redis·缓存
Nturmoils39 分钟前
DolphinDB 实时时序数据处理踩坑实录:5 类生产故障排查与优化
数据库
csdn2015_1 小时前
postgresql 拼接字段
数据库
\xin1 小时前
pikachu自编SQL(POST)
java·数据库·sql
oldking呐呐1 小时前
MySQL从建库到删库跑路 -- 4.表的操作
后端·mysql
2301_815901971 小时前
SQL如何将多行记录聚合成逗号分隔字符串_GROUP_CONCAT技巧
jvm·数据库·python
秋91 小时前
Kingbase下载、安装和使用详解
数据库
zjy277772 小时前
Layui tab选项卡如何动态根据ID值进行程序化切换
jvm·数据库·python