问题描述
服务器使用的是宝塔面板CentOS环境,本地用Navicat操作远程MySQL数据库时经常会出现“正在准备…”、“正在加载…”等待时间特别长的情况,有时要等待十几秒。
原因分析
MySQL服务器端会定时清理长时间不活跃空闲的数据库连接,以此优化数据库的性能。
Navicat客户端有一个设置:保持连接间隔,默认是240秒!意思是,客户端在用户无任何交互性操作时,会每隔240秒给MySQL服务端发送一次数据请求。以此来保持数据库连接活跃。
然而Navicat设置的心跳包间隔太长了,MySQL服务端直接将连接清理掉了。当我们打开一张表的时候,Navicat还是使用旧的连接去请求数据,发现旧的连接超时不能用了,最后又申请了一个新的连接,再去请求数据。
所以导致我们打开一张表时间需要挺久的!
解决方案
Navicat – 编辑数据库连接 – 高级 – 勾选保持连接间隔 – 输入框设置为30 – 点击确定!