一招解决Navicat连接线上数据库时,隔一段时间不操作出现的卡顿问题

项目场景:

  后端开发,肯定离不开和数据库打交道,现在Java项目绝大多数都是使用MySQL数据库,所以Navicat for MySQL这个数据库可视化工具,大家就不会陌生了。


问题描述

  使用 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 – 找到对应的数据库 – 右键 – 连接属性 – 高级 – 勾选保持连接间隔(秒) – 输入框设置为30 (建议30-240之间,不要超过240)– 点击确定!

在这里插入图片描述

大功告成!!!赶紧去试试吧!

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程序yang

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

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

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

打赏作者

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

抵扣说明:

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

余额充值