最近网站流量增加,以前的主机已不能满足现在的访问量。于是,打算换主机,本来觉得换个主机给网站搬个家不是个事儿呢。结果,在实际操作过程中出了不少岔子,今天就来记录总结下。
背景
在把网站数据库备份文件(.sql 文件)导入新的数据库时,出现了“[Err] 2006 - MySQL server has gone away”错误提示。
原因
可能是 sql 语句过长(sql 文件过大),超过 mysql 通信缓存区最大长度。
解决办法
找到 mysql 安装目录下的 my.ini 配置文件,加入以下代码:
max_allowed_packet=50M
参数注释如下:
max_allowed_packet 是 mysql 允许最大的数据包,用来控制其通信缓冲区的最大长度。
最后重启下 mysql 服务。就解决了我的问题,不过造成这个问题的原因还有其他几种。
延伸
1、应用程序(比如 PHP)长时间的执行批量的 MYSQL 语句。
最常见的就是采集或者新旧数据转化。
解决方案:
在 my.ini 文件中添加或者修改以下两个变量:
wait_timeout=2880000
interactive_timeout = 2880000
2、执行一个 SQL,但 SQL 语句过大或者语句中含有 BLOB 或者 longblob 字段。
比如,图片数据的处理。解决方案是:
在 my.ini 文件中添加或者修改以下变量:
max_allowed_packet = 10M(默认为 1M,也可以设置自己需要的大小)
max_allowed_packet 参数的作用是,用来控制其通信缓冲区的最大长度。
最保险的方法:
将 2 段代码都加上:
max_allowed_packet=50M
wait_timeout=288000
interactive_timeout = 288000
更多原因查看链接》》》http://www.jb51.net/article/23781.htm
声明:此资源由沃森博客 [wosn.net] 收集整理于网络,如有侵权,请联系沃森博客 [admin@wosn.net] 删除处理。
沃森博客(wosn.net)--- 专注于 PHP 技术和资源分享!
评论