MySQL:The last packet sent successfully to the server was 0 milliseconds ago.

出现异常”The last packet sent successfully to the server was 0 milliseconds ago.“的大部分原因是由于数据库回收了连接,而系统的缓冲池不知道,继续使用被回收的连接所致的

解决方法: 

(1)使用JDBC URL中使用autoReconnect属性

&autoReconnect=true&failOverReadOnly=false

(2) 修改MySQL的参数. /etc/my.cnf 添加 

将mysql回收空闲连接的时间变长,mysql默认回收时间是8小时,可以在mysql目录下的my.cnf中增加下面配置,将时间修改长一点

[mysqld]
wait_timeout=31536000
interactive_timeout=31536000

(3)重启mysql 

service mysql restart

原因分析: 
(1)大量数据访问情况下,mysql connection连接有可能失效 
(2)长时间不妨问,connection会失效 

也可以通过配置,让缓冲池去测试连接是否被回收,如果被回收,则不继续使用,以dbcp为例:

#SQL查询,用来验证从连接池取出的连接
dbcp.validationQuery=SELECT 1
#指明连接是否被空闲连接回收器(如果有)进行检验,如果检测失败,则连接将被从池中去除
dbcp.testWhileIdle=true
#在空闲连接回收器线程运行期间休眠的时间值,以毫秒为单位,一般比minEvictableIdleTimeMillis小
dbcp.timeBetweenEvictionRunsMillis=300000
#在每次空闲连接回收器线程(如果有)运行时检查的连接数量,最好和maxActive一致
dbcp.numTestsPerEvictionRun=50
#连接池中连接,在时间段内一直空闲,被逐出连接池的时间(1000*60*60),以毫秒为单位
dbcp.minEvictableIdleTimeMillis=3600000

相关推荐

  1. 0. 前言

    2024-01-13 21:42:05       39 阅读
  2. 127.0.0.1和0.0.0.0的区别

    2024-01-13 21:42:05       51 阅读
  3. IP地址 0.0.0.0 和 127.0.0.1之间的区别

    2024-01-13 21:42:05       34 阅读
  4. 云服务器,nginx访问失败,安全组,0.0.0.0/0

    2024-01-13 21:42:05       27 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-13 21:42:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-13 21:42:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-13 21:42:05       82 阅读
  4. Python语言-面向对象

    2024-01-13 21:42:05       91 阅读

热门阅读

  1. C++ 并发编程 | 并发世界

    2024-01-13 21:42:05       64 阅读
  2. QT基础篇(4)QT5基本对话框

    2024-01-13 21:42:05       48 阅读
  3. C++ (MFC) 单程序运行(防止多开程序)

    2024-01-13 21:42:05       68 阅读
  4. go如何终止多个for select循环嵌套

    2024-01-13 21:42:05       52 阅读