1、起源
在某一天突然来了一个需求,大量更新一个表的数据,需要时间 50秒以上那种。然后事情就来了,概率报错数据库了解超时或者异常
shell
### Error updating database. Cause: com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure
The last packet successfully received from the server was 6,001 milliseconds ago. The last packet sent successfully to the server was 6,001 milliseconds ago.
### The error may exist in file [D:\java\saiyo\sy-ifm-backend-2023\saiyo-module-mdl\saiyo-module-mdl-biz\target\classes\mapper\admin\shadow\ShadowMapper.xml]
### The error may involve defaultParameterMap
### The error occurred while setting parameters
2、配置
数据库连接池使用以来版本如下
xml
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.18</version>
</dependency>
2、归源
经过漫长搜索资料之后发现扯淡太多了,回归本质翻到了druid的代码仓库看到了发版历史
connectTimeout和socketTimeout
看到这两个扎心的参数,直接天灵盖一凉,坑啊 再往下翻到Druid 1.2.12
终于找到了坑自何处,学艺不精吃了默认配置的亏啊。
3、解决
添加配置如下
yaml
druid: # Druid 【连接池】相关的全局配置
initial-size: 5 # 初始连接数
min-idle: 5 # 最小连接池数量
max-active: 20 # 最大连接池数量
connect-timeout: 10000
socket-timeout: 1100000
4、druid配置在线地址
5、【另记】mysql 事务等待超时
在MySQL数据库中,事务超时主要涉及到两个参数:innodb_lock_wait_timeout
和 wait_timeout
。这两个参数决定了事务在等待资源或锁定时的最大等待时间。
- innodb_lock_wait_timeout:这是InnoDB存储引擎特有的参数,用于定义一个事务在等待行锁时的最大时间。如果在这个时间内事务没有获得所需的锁,它将抛出一个超时错误(例如 "Lock wait timeout exceeded; try restarting transaction")。默认情况下,这个值通常是50秒。
- wait_timeout:这个参数定义了非活动连接的超时时间,即如果一个连接在指定的时间内没有任何动作,MySQL服务器将自动关闭这个连接。默认值通常是8小时(28800秒),但这个值可以在全局或会话级别进行调整。