com.mysql.jdbc.exceptions.jdbc4.CommunicationsE...

解决com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure 的错误

分析原因:

首先在mysql下用命令:mysql﹥ show global variables like 'wait_timeout'; 查看wait_timeout

这里我的wait_timeout是60也就是一分钟,设置默认值太小

(取值范围:1-31536000(linux),interactive_time取值随wait_timeout变动)

所以如果在wait_timeout秒期间内,数据库连接(java.sql.Connection)一直处于等待状态,mysql就将该连接关闭。这时,你的Java应用的连接池仍然合法地持有该连接的引用。当用该连接来进行数据库操作时,就碰到上述错误。

解决:在linux系统配置文件:/etc/my.cnf 

1.修改配置 

vi /etc/my.cnf 

wait_timeout = 604800

interactive_timeout = 604800

2:重启mysql服务( service mysqld restart)
 

# /etc/init.d/mysql restart 

到此那么连接超时的问题从数据库上就解决了。

备注:

 interactive_timeout:服务器关闭交互式连接前等待活动的秒数

 wait_timeout:服务器关闭非交互连接之前等待活动的秒数

 

后续有很多开发填坑的文章发布,如果对你有帮助,请支持和加关注一下

http://e22a.com/h.05ApkG?cv=AAKHZXVo&sm=339944

https://shop119727980.taobao.com/?spm=0.0.0.0 

 

转载于:https://my.oschina.net/baishi/blog/172856

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值