上云后mysql默认wait_timeout导致应用层很多连接不可用

上云后mysql默认wait_timeout导致应用层很多连接不可用

  • [1. 现象](#1. 现象)
  • [2. 原因](#2. 原因)
    • [为什么云服务器(阿里云、腾讯云)通常更需要把 timeout 设小?](#为什么云服务器(阿里云、腾讯云)通常更需要把 timeout 设小?)
      • [因此,如果你把 wait_timeout 设置很大,会发生什么?](#因此,如果你把 wait_timeout 设置很大,会发生什么?)
  • [3. 解决](#3. 解决)
    • [3.1 mysql服务器修改wait_timeout](#3.1 mysql服务器修改wait_timeout)
    • [3.2 业务系统连接池的配置修改](#3.2 业务系统连接池的配置修改)

1. 现象

系统部署在阿里云服务器中,mysql正常部署,但业务系统经常报错,几种报错的内容如下

①. Connection com.mysql.cj.jdbc.ConnectionImpl@45ed27d2 marked as broken because of SQLSTATE(08S01), ErrorCode(1160)

②. Could not roll back JDBC transaction: nested exception is java.sql.SQLException: Connection is closed

③. Could not open JDBC Connection for transaction; nested exception is com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure

2. 原因

为什么云服务器(阿里云、腾讯云)通常更需要把 timeout 设小?

在云环境中,网络设备会主动清理"长时间不活跃的 TCP 连接",包括:

• 云防火墙

• SLB(负载均衡)

• VPC 虚拟网络

• 安全组防火墙

• NAT 网关

• TCP keepalive 机制

这些设备都会 "默默" 关闭长时间不活跃的连接。

因此,如果你把 wait_timeout 设置很大,会发生什么?

应用层以为连接还在

但底层网络已经把 TCP 连接关闭

下一次用这个连接时就会抛异常:

Communications link failure

mysql默认的wait_timeout: 28800 单位秒,8小时。
这在平时开发测试环境是没有问题的;但上云后会出现这样的问题;

3. 解决

3.1 mysql服务器修改wait_timeout

复制代码
# 设置非交互连接的超时时间
wait_timeout = 900          # 15 分钟
interactive_timeout = 900   # 15 分钟

重启mysql
systemctl restart mysql

验证生效
SHOW VARIABLES LIKE 'wait_timeout';

3.2 业务系统连接池的配置修改

这里以HikariCP为例。

spring: 复制代码
  datasource:
    hikari:
      # 连接池中允许的最大连接数 (默认: 10)
      maximum-pool-size: 20      
      # 连接池中保持的最小空闲连接数 (建议与maximum-pool-size相同)
      minimum-idle: 2      
      # 连接超时时间 (毫秒) (默认: 30000)
      connection-timeout: 30000      
      # 连接最大存活时间 (毫秒) (建议比数据库wait_timeout小2-3分钟)
      max-lifetime: 840000  # 15分钟      
      # 连接空闲超时时间 (毫秒) (默认: 600000)
      idle-timeout: 600000  # 10分钟      
      # 连接测试查询 (部分数据库需要)
      connection-test-query: SELECT 1

核心就是max-lifetime < mysql中的wait_timeout

相关推荐
小北方城市网2 分钟前
Spring Cloud Gateway 自定义过滤器深度实战:业务埋点、参数校验与响应改写
运维·jvm·数据库·spring boot·后端·mysql
Gary董3 分钟前
redis 和 mongoDB 的优劣
数据库·redis·mongodb
indexsunny11 分钟前
互联网大厂Java面试实录:Spring Boot微服务在电商场景中的应用与挑战
java·spring boot·redis·mysql·security·microservices·interview
海星船长丶16 分钟前
预编译与sql注入,正则回溯绕过,mysql常见绕过,报错注入7大常用函数
服务器·数据库·sql·mysql·网络安全
一只自律的鸡18 分钟前
【MySQL】第七章 数据库, 表, 数据的增删改查
数据库·oracle
PythonFun21 分钟前
WPS单元格中如何分别设置中英字体为不同字号
数据库·mysql·wps
GISer_Jing23 分钟前
大语言模型Agent入门指南
前端·数据库·人工智能
Mikhail_G32 分钟前
Mysql数据库操作指南——数据库(零基础篇)
大数据·数据库·sql·mysql·数据分析
沉淅尘42 分钟前
Context Engineering: 优化大语言模型性能的关键策略与艺术
数据库·人工智能·语言模型
重生之绝世牛码1 小时前
Linux软件安装 —— Elasticsearch集群安装(带密码验证)
大数据·linux·运维·数据库·elasticsearch·软件安装