使用 Navicat 连接服务器上的数据库时,如果隔一段时间没有使用,再次点击就会出现卡顿的问题。
如:隔一段时间再查询完数据会出现:
2013 - Lost connection to MySQL server at 'waiting for initial communication packet', system error: 0
原因:
Mysql 服务端会定时清理长时间不活跃空闲的数据库连接,以优化数据库的性能。
Navicat 客户端有一个设置:保持连接间隔,默认是 240 秒,即客户端在用户无任何交互性操作时,会每隔 240 秒给 Mysql 服务端发送一次数据请求,以此来保持数据库连接活跃。
但是Navicat 设置的心跳检测间隔太长了,Mysql 服务端直接将连接清理掉了。
所以,当我们再次执行语句时,Navicat 还是使用旧的连接去请求数据,发现旧的连接超时不能用了,最后又申请了一个新的连接,再去请求数据,因此过一会再次使用时 Navicat 会卡顿一会儿。
解决:
Navicat –> 对应数据库 –> 右键编辑连接 –> 高级 – 勾选保持连接间隔(秒) – 输入框设置为60