wordpress国内网站吗,免费注册域名邮箱,网络营销方式有哪些?,淮南房地产网站建设网站最近做测试#xff0c;发现Mysql 过一段时间会无法连接#xff0c;导致数据库数据不一至#xff0c;极其郁闷。
使用Connector/J连接MySQL数据库#xff0c;程序运行较长时间后就会报以下错误#xff1a;
Communications link failure#xff0c;The last packet succ…最近做测试发现Mysql 过一段时间会无法连接导致数据库数据不一至极其郁闷。
使用Connector/J连接MySQL数据库程序运行较长时间后就会报以下错误
Communications link failureThe last packet successfully received from the server was *** millisecond ago.The last packet successfully sent to the server was *** millisecond ago。
其中错误还会提示你修改wait_timeout或是使用Connector/J的autoReconnect属性避免该错误。
后来查了一些资料才发现遇到这个问题的人还真不少大部分都是使用连接池方式时才会出现这个问题短连接应该很难出现这个问题。这个问题的原因
MySQL服务器默认的“wait_timeout”是28800秒即8小时意味着如果一个连接的空闲时间超过8个小时MySQL将自动断开该连接而连接池却认为该连接还是有效的(因为并未校验连接的有效性)当应用申请使用该连接时就会导致上面的报错。
1.按照错误的提示可以在JDBC URL中使用autoReconnect属性实际测试时使用了autoReconnecttruefailOverReadOnlyfalse不过并未起作用使用的是5.1版本可能真像网上所说的只对4之前的版本有效。
2.没办法只能修改MySQL的参数了wait_timeout最大为31536000即1年在my.cnf中加入
[mysqld]
wait_timeout31536000
interactive_timeout31536000
重启生效需要同时修改这两个参数。