碰到一个很郁闷的问题,就是提示这个错误。在测试服务器没一点问题,打包到正式上面就出现这个错误,而且是一直出现。相当的让我痛苦?!
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以及解决方案!
各位小伙伴,有什么不足的地方,欢迎底下留言,谢谢!