一、前言🔥
👨🎓作者:bug菌
💌公众号:猿圈奇妙屋
🚫特别声明:原创不易,转载请附上原文出处链接和本文声明,谢谢配合。
🙏版权声明:文章里可能部分文字或者图片来源于互联网或者百度百科,如有侵权请联系bug菌处理。
哈喽,小伙伴们,我是bug菌呀👀,不知不觉就一年又4月,正是踏青郊游的好时节。可上海疫情,除了在家远程办公就是看点技术顺便卷点文章。这不是4月又出了更文活动,逼自己一把,坚持每天做点内容输出,养成写作习惯,将来你会回来感谢曾经的自己坚持了一把才有此刻的辉煌成就。
小伙伴们在批阅文章的过程中如果觉得文章对您有一丝丝帮助,还请别吝啬您手里的赞呀,大胆的把文章点亮👍吧,您的点赞三连(收藏⭐️+关注👨🎓+留言📃)就是对bug菌我创作道路上最好的鼓励与支持😘。时光不弃🏃🏻♀️,掘金不停💕,加油☘️
二、环境说明🔥
**环境:**jdk1.8 + springboot 2.3.1.RELEASE + mysql 5.6
三、排错分析🔥
非常的奇怪,巨离谱!项目本地运行,时不时给你卡一下,然后控制台直接报错哗哗的一行行打印,且不光印象接口访问,navicat连接刷新数据库也是,直接卡住,这才多少数据,百来条,就直接查询也不至于啊?
前端放来狠话,说我接口频繁报错,一会儿又好了,给我紧急修复掉,太影响接口测试了。这把我给整的,很烦呀,这任谁也忍不了呀,必须解决!
放眼望去,从何开始定位问题呢?先申明一下不是锁表锁库所导致!这点是可以排除的。有哪位懂行的老哥能帮帮我的么?
四、报错展示🔥
如下是我项目控制台实际报错:
WARN 4196 --- [nio-8889-exec-6] com.zaxxer.hikari.pool.PoolBase : master - Failed to validate connection com.mysql.cj.jdbc.ConnectionImpl@4270a6d1 (No operations allowed after connection closed.). Possibly consider using a shorter maxLifetime value. WARN 4196 --- [nio-8889-exec-6] com.zaxxer.hikari.pool.PoolBase : master - Failed to validate connection com.mysql.cj.jdbc.ConnectionImpl@74713539 (No operations allowed after connection closed.). Possibly consider using a shorter maxLifetime value. WARN 4196 --- [nio-8889-exec-6] com.zaxxer.hikari.pool.PoolBase : master - Failed to validate connection com.mysql.cj.jdbc.ConnectionImpl@3b7db2ff (No operations allowed after connection closed.). Possibly consider using a shorter maxLifetime value. WARN 4196 --- [nio-8889-exec-6] com.zaxxer.hikari.pool.PoolBase : master - Failed to validate connection com.mysql.cj.jdbc.ConnectionImpl@15d8fec0 (No operations allowed after connection closed.). Possibly consider using a shorter maxLifetime value.
五、解决方案🔥
单从报错信息入手:验证连接com.mysql.cj.jdbc
失败,连接关闭后不允许操作。可以考虑减小的maxLifetime值。
但从报错信息入手,好像有点眉头,我们可以先查看一下你们的数据库超时参数配置。很有可能是超时则断开连接导致。
如下是两种尝试解决方案,仅供参考,如果方案1设置不好使请尝试方案2。不能保证方案对你们的情况是否有效,但是总比不尝试强!
方案1:
执行如下这段命令查看数据库的各种超时配置参数:
show variables like '%timeout%';
实际查询结果如下:
从上述截图结果上可以明显看到:连接超时时间使用的是默认的8小时(28800秒),查阅资料发现在mysql 5以上的版本修改my.cnf这个文件,自定义配置wait_timeout
与 interactive_timeout
,这个文件的位置位于你服务器里根目录下的 /etc/my.cnf
路径下。
vim编辑打开文件后,在 [mysqld
] 的最后一行加上如下参数;
wait_timeout= 86400
我们直接修改超时等待时长为:
wait_timeout= 86400
实际修改截图:
下面重启下mysql
service mysqld restart
实际运行截图:
OK,我们可以执行命令检查一下。
show variables like '%timeout%';
方案2:
如果有的小伙伴修改了设置了my.cnf配置依旧参数没有变化,连接超时时间没有变更,那我们就在服务器直接通过命令连接,然后再设置参数试试:
连接数据库命令:
mysql -u root -h ip -p
然后输入数据库连接密码,后回车。
我们再直接执行一遍查询命令:show variables like ‘%timeout%‘;
可以看到,默认是8小时(28800秒),然后我们通过命令式的设置进行修改参数:
set interactive_timeout=604800; set wait_timeout=604800;
实际设置截图:
都显示设置成功了。那我们直接查询一下:
这样只是说明你设置好了,但是要想立即生效,那我们还得重启下服务器:
service mysqld restart
实际设置截图:
可以看到,数据库已经重启好了,那我们再来监听看看,后端服务是否还会报连接超时问题吧!
可以检查下数据库服务有没有重启OK,确保下。
service mysqld status
实际运行截图:
... ...
ok,以上这样就好啦,如果还想学习更多,你可以看看我的往期热文推荐哦,每天积累一个奇淫小知识,日积月累下去,你一定能成为令人敬仰的大佬的。好啦,咱们下期见~
六、往期推荐🔥
- springboot之jar包Linux后台启动部署及滚动日志查看且日志输出至文件保存(上篇)
- Springboot系列(十六):集成easypoi实现Excel导出
- Springboot系列(十六):集成easypoi实现单word模板导出多页面
- Springboot系列(十六):集成easypoi实现word模板内循环导出多数据
- Springboot系列(十六):集成easypoi实现word模板图片导出
- Springboot系列(十六):集成easypoi实现excel多sheet表导入
- Springboot系列(十六):集成easypoi实现excel多sheet表导出
七、文末🔥
如果还想要学习更多,小伙伴们可关注bug菌专门为大家创建的专栏《SpringBoot零基础入门》,从无到有,从零到一!希望能帮到大家。
我是bug菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!