Mysql出现连接问题,连接超时问题。。。

菜鸟一枚,接触开发不到半年,在此做一个记录。
在公司做了一个小网站,数据页面老是出问题。但本地项目没有问题,服务器上部署的项目却出现问题,报Hibernate之类的错误。明显是数据库的错误。
于是重新导数据,发现报Lost connection to MySQL server during query unsuccessful的错误。

丢失连接,经过几次问题的处理,在此总结一下:

mysql连接超时,长时间不操作数据库丢失连接,so要想办法解决啊!
mysql中它有一个默认的连接超时的设置,wait_timeout,默认为28000是8个小时。
我们可以通过设置wait_timeout来加长时间,但还有一个方法:
1.在程序中设置多长时间查询语句,保持mysql的连接正常;
2.设置wait_timeout如果你没有修改过MySQL的配置,缺省情况下,wait_timeout的初始值是28800。
进入mysql的控制器,进入mysql的bin目录下的路径
mysql -hlocalhost -uroot -p****
这里写图片描述
//-h是当前数据库地址,这里是localhost,-u是用户名,-p是密码

进入后 show variable like ‘%timeout%’;
这里写图片描述
显示wait_timeout = 28800;
去mysql中的my.ini中添加wait_time = 1388000
查 看mysql5的手册,对wait_timeout的最大值分别是24天/365天(windows/linux)。重新启动Mysql


发现 show variable like ‘%timeout%’;
wait_timeout = 28800;
没有更改,这是查询 show global variables like ‘wait_timeout’;
这里写图片描述
这 里一个容易把人搞蒙的地方是如果查询时使用的是show variables的话,会发现设置好像并没有生效,这是因为单纯使用show variables的话就等同于使用的是show session variables,查询的是会话变量,只有使用show global variables,查询的才是全局变量。

很多人都抱怨说set global之后使用show variables查询没有发现改变,原因就在于混淆了会话变量和全局变量,如果仅仅想修改会话变量的话,可以使用类似set wait_timeout=10;或者set session wait_timeout=10;这样的语法。


在此记录……

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值