提升性能:数据库与 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 开启批量插入 / 更新优化,提升写性能
相关推荐
马克Markorg2 小时前
常见的向量数据库和具有向量数据库能力的数据库
数据库
Coder_Boy_4 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy4 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道6 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707536 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha6 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_6 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance6 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋6 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.7 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库