上云优惠聚集地,云小站专属折扣优惠。
https://www.aliyun.com/minisite/goods?userCode=7yp9j8y0🚀 提升性能:数据库与 Druid 连接池优化指南
结合,服务器内存处理器小导致查询慢或数据量大查询慢,容易被锁等场景,我帮你梳理一下MySQL 配置 和Druid 连接池配置的关键优化点,直接上可落地的配置方案。
🔧 一、MySQL 数据库配置优化
这些配置修改需要在 my.cnf 或 my.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
🎯 三、核心优化逻辑说明
-
减少 Sleep 连接堆积
- MySQL 端:
wait_timeout=60让数据库主动关闭空闲连接; - Druid 端:
min-evictable-idle-time-millis=300000让连接池主动回收空闲超过 5 分钟的连接,避免连接泄漏。
- MySQL 端:
-
提升连接复用效率
max-active设为 20,避免连接数过多导致 MySQL 上下文切换开销;test-on-borrow=false减少连接检测的性能损耗,依赖test-while-idle保证连接有效性。
-
适配 MySQL 8.0 + 驱动
- URL 中添加
allowPublicKeyRetrieval=true避免驱动连接报错; rewriteBatchedStatements=true开启批量插入 / 更新优化,提升写性能
- URL 中添加