MySQL数据库报错:Communications link failure due to underlying exception,解决方案

碰到一个很郁闷的问题,就是提示这个错误。在测试服务器没一点问题,打包到正式上面就出现这个错误,而且是一直出现。相当的让我痛苦?!
2019-03-01T06:26:08.334418305Z Last packet sent to the server was 1 ms ago.; nested exception is com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception: 
2019-03-01T06:26:08.334424043Z ** BEGIN NESTED EXCEPTION ** 
2019-03-01T06:26:08.334429484Z java.io.EOFException
2019-03-01T06:26:08.334432262Z MESSAGE: Can not read response from server. Expected to read 4 bytes, read 0 bytes before connection was unexpectedly lost.
2019-03-01T06:26:08.334437891Z STACKTRACE:
2019-03-01T06:26:08.334443619Z java.io.EOFException: Can not read response from server. Expected to read 4 bytes, read 0 bytes before connection was unexpectedly lost.

因为使用的docker部署服务,期初一直的以为连接数据库错误是由于docker造成的bug问题!所以docker镜像也都换了一个,还是出现这个错误?!

后面经过一番调研,觉得可能还是因为数据库的问他。mysql5将其连接的默认等待时间(wait_timeout)缺省为8小时。

然后使用:show variables like '%wait_time%'; 查看发现这个是默认的是28800 seconds,也就是8小时,没错啊!!!!

再经过一番调研,使用全局的变量查看,发现居然配置的是10、10、10 啊!!!!!

show global variables like 'wait_timeout';

哎,没办法之前一番痛苦咋就没想到这裁!!

set global wait_timeout=28800 ; 

通过以上命令设置成,项目运行正常!!以此记录下出现的bug以及解决方案!

各位小伙伴,有什么不足的地方,欢迎底下留言,谢谢!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薄伤一宰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值