Java | The last packet sent successfully to the server was xxx milliseconds ago

最近在部署代码后,后端总是会遇到这个问题,设备通道在访问数据库时经常会报错,在搜集大量资料后我以为是配置问题,首先要保证:

(1)首先确定jdbc.url地址是正确的

(2)修改wait_timeout和interactive_timeout

(3)修改mysql驱动版本,将版本提升,所以建议如果修改timeout不成功的话,一定要将驱动版本升级一下再试试

我这里服务器的版本是mysql5.7.41,JDBC-connect是用的8.0.11,故没有上述问题。

所以我以为是第二个问题,因为我这边总是显示收到数据距上一次收到 一直是120s 左右的时间。

但是在云服务器上更改mysql的配置文件后,根据mysql命令进入命令行还是查询不到更改的timeout值,一直是300.

直到后来!!!我一直看每次的Exception都是间隔120s左右!

我将请求更改到100s就不会出现问题!

所以!我又在 后端代码 使用代码访问数据库发现这里的timeout一个是120,一个是300!

终于破案了!

还是mysql 的 timeout变量的问题。

如果查询时使用的是show variables的话, 会发现设置并没有生效, 除非重新登录再查看.

这是因为使用show variables的话就等同于使用show session variables, 查询的是会话变量, 只有使用show global variables查询的才是全局变量.

如果仅仅想修改会话变量的话, 可以使用

类似set wait_timeout=10;或者set session wait_timeout=10;这样的语法.


附上一些修改的命令:

root@YousunIOTServer \~# which mysql

/usr/bin/mysql

root@YousunIOTServer \~# mysql --verbose --help|grep -A 1 'Default options'

Default options are read from the following files in the given order:

/etc/my.cnf /etc/mysql/my.cnf /usr/etc/my.cnf ~/.my.cnf

root@YousunIOTServer \~#

rm -f /user/bin/.my.cnf.swp

rm -f /etc/.my.cnf.swp

把my.cnf配置文件加个max_connections包括(插入命令,删除命令,修改命令。退出保存命令)

你要有这个文件写权限,shell下输入:

vi /etc/my.cnf

进入vi后,按i

移动上下左右键到,你想插入的位置,然后打字。这时跟记事本是一样的。

打完字后,按ESC

然后输入

:wq

就保存退出了。

启动数据库服务:systemctl start mysqld.service

重启数据库服务:service mysqld restart

查看数据库运行状态:service mysqld status

查看最大连接数:show variables like '%max_connections%';

查看最大使用连接:show global status like 'Max_used_connections';


部分参考:

了解超时 - JDBC Driver for SQL Server | Microsoft Learn

https://www.cnblogs.com/devcjq/articles/6409470.html

一篇文章彻底理解数据库的各种 JDBC 超时参数 - 知乎

相关推荐
2601_961875243 分钟前
法考备考计划表|学习计划|资料已整理
java·开发语言·学习·eclipse·tomcat·c#·hibernate
青春:一叶知秋3 分钟前
【Python】python基本语法和使用
开发语言·python
SilentSamsara9 分钟前
向量数据库实战:Chroma/Milvus/Qdrant 选型与语义搜索应用
开发语言·数据库·人工智能·python·青少年编程·milvus
重生之我是Java开发战士13 分钟前
【Java SE】多线程(三):单例模式,阻塞队列,线程池与定时器
java·javascript·单例模式
AI人工智能+电脑小能手17 分钟前
【大白话说Java面试题 第115题】【并发篇】第15题:说一下悲观锁和乐观锁的区别?
java·开发语言·面试
lijgvnns24 分钟前
个人AI编程工具的vibe coding实践:从爬虫到导出Excel的全流程
开发语言·javascript·ecmascript
心之伊始30 分钟前
Spring Boot Actuator + Micrometer 实战:自定义业务指标并接入 Prometheus 观测接口耗时
java·spring boot·prometheus·actuator·micrometer
Full Stack Developme34 分钟前
Spring Integration 教程
java·后端·spring
青春喂了后端38 分钟前
Go Sidecar Status 性能优化
开发语言·性能优化·golang
摇滚侠41 分钟前
MyBatis 入门到项目实战 MyBatis 分页插件 65-66
java·开发语言·sql·mybatis